home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
browse contents |
view JSON data
|
view as text
This file was processed as: Mailbox/MIME Entity
(archive/mbox).
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| dexvert
| Mailbox/MIME Entity (archive/mbox)
| magic
| Supported |
100%
| dexvert
| Internet Message Format (text/imf)
| magic
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| Mailbox text, 1st line "From pacbell!ames!mailrus!cornell!rochester!bbn!bbn.com!rsalz Fri Jul 1 13:13:46 1988", ASCII text, with CRLF line terminators
| default
| |
100%
| TrID
| E-Mail message (Var. 2)
| default
| |
100%
| perlTextCheck
| Likely Text (Perl)
| default
| |
100%
| detectItEasy
| Format: Plain text[CRLF]
| default
| |
100%
| xdgMime
| application/mbox
| default (weak)
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 46 72 6f 6d 20 70 61 63 | 62 65 6c 6c 21 61 6d 65 |From pac|bell!ame|
|00000010| 73 21 6d 61 69 6c 72 75 | 73 21 63 6f 72 6e 65 6c |s!mailru|s!cornel|
|00000020| 6c 21 72 6f 63 68 65 73 | 74 65 72 21 62 62 6e 21 |l!roches|ter!bbn!|
|00000030| 62 62 6e 2e 63 6f 6d 21 | 72 73 61 6c 7a 20 46 72 |bbn.com!|rsalz Fr|
|00000040| 69 20 4a 75 6c 20 20 31 | 20 31 33 3a 31 33 3a 34 |i Jul 1| 13:13:4|
|00000050| 36 20 31 39 38 38 0d 0a | 46 72 6f 6d 3a 20 72 73 |6 1988..|From: rs|
|00000060| 61 6c 7a 40 62 62 6e 2e | 63 6f 6d 20 28 52 69 63 |alz@bbn.|com (Ric|
|00000070| 68 20 53 61 6c 7a 29 0d | 0a 4e 65 77 73 67 72 6f |h Salz).|.Newsgro|
|00000080| 75 70 73 3a 20 63 6f 6d | 70 2e 73 6f 75 72 63 65 |ups: com|p.source|
|00000090| 73 2e 75 6e 69 78 0d 0a | 53 75 62 6a 65 63 74 3a |s.unix..|Subject:|
|000000a0| 20 76 31 35 69 30 38 31 | 3a 20 20 41 52 43 20 28 | v15i081|: ARC (|
|000000b0| 50 43 20 63 6f 6d 70 72 | 65 73 73 69 6f 6e 20 70 |PC compr|ession p|
|000000c0| 72 6f 67 72 61 6d 29 2c | 20 76 35 2e 32 31 2c 20 |rogram),| v5.21, |
|000000d0| 50 61 72 74 30 35 2f 30 | 35 0d 0a 4d 65 73 73 61 |Part05/0|5..Messa|
|000000e0| 67 65 2d 49 44 3a 20 3c | 39 36 39 40 66 69 67 2e |ge-ID: <|969@fig.|
|000000f0| 62 62 6e 2e 63 6f 6d 3e | 0d 0a 44 61 74 65 3a 20 |bbn.com>|..Date: |
|00000100| 31 20 4a 75 6c 20 38 38 | 20 32 30 3a 31 33 3a 34 |1 Jul 88| 20:13:4|
|00000110| 36 20 47 4d 54 0d 0a 0d | 0a 53 75 62 6d 69 74 74 |6 GMT...|.Submitt|
|00000120| 65 64 2d 62 79 3a 20 68 | 79 63 40 6d 61 74 68 2e |ed-by: h|yc@math.|
|00000130| 6c 73 61 2e 75 6d 69 63 | 68 2e 65 64 75 0d 0a 50 |lsa.umic|h.edu..P|
|00000140| 6f 73 74 69 6e 67 2d 6e | 75 6d 62 65 72 3a 20 56 |osting-n|umber: V|
|00000150| 6f 6c 75 6d 65 20 31 35 | 2c 20 49 73 73 75 65 20 |olume 15|, Issue |
|00000160| 38 31 0d 0a 41 72 63 68 | 69 76 65 2d 6e 61 6d 65 |81..Arch|ive-name|
|00000170| 3a 20 61 72 63 35 2e 32 | 31 2f 70 61 72 74 30 35 |: arc5.2|1/part05|
|00000180| 0d 0a 0d 0a 23 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |....#---|--------|
|00000190| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001a0| 2d 2d 2d 2d 2d 43 55 54 | 20 48 45 52 45 2d 2d 2d |-----CUT| HERE---|
|000001b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000001d0| 2d 2d 0d 0a 23 21 20 2f | 62 69 6e 2f 73 68 0d 0a |--..#! /|bin/sh..|
|000001e0| 23 0d 0a 23 20 54 68 69 | 73 20 69 73 20 61 20 73 |#..# Thi|s is a s|
|000001f0| 68 65 6c 6c 20 61 72 63 | 68 69 76 65 2e 20 20 53 |hell arc|hive. S|
|00000200| 61 76 65 20 74 68 69 73 | 20 69 6e 74 6f 20 61 20 |ave this| into a |
|00000210| 66 69 6c 65 2c 20 65 64 | 69 74 20 69 74 0d 0a 23 |file, ed|it it..#|
|00000220| 20 61 6e 64 20 64 65 6c | 65 74 65 20 61 6c 6c 20 | and del|ete all |
|00000230| 6c 69 6e 65 73 20 61 62 | 6f 76 65 20 74 68 69 73 |lines ab|ove this|
|00000240| 20 63 6f 6d 6d 65 6e 74 | 2e 20 20 54 68 65 6e 20 | comment|. Then |
|00000250| 67 69 76 65 20 74 68 69 | 73 0d 0a 23 20 66 69 6c |give thi|s..# fil|
|00000260| 65 20 74 6f 20 73 68 20 | 62 79 20 65 78 65 63 75 |e to sh |by execu|
|00000270| 74 69 6e 67 20 74 68 65 | 20 63 6f 6d 6d 61 6e 64 |ting the| command|
|00000280| 20 22 73 68 20 66 69 6c | 65 22 2e 20 20 54 68 65 | "sh fil|e". The|
|00000290| 20 66 69 6c 65 73 0d 0a | 23 20 77 69 6c 6c 20 62 | files..|# will b|
|000002a0| 65 20 65 78 74 72 61 63 | 74 65 64 20 69 6e 74 6f |e extrac|ted into|
|000002b0| 20 74 68 65 20 63 75 72 | 72 65 6e 74 20 64 69 72 | the cur|rent dir|
|000002c0| 65 63 74 6f 72 79 20 6f | 77 6e 65 64 20 62 79 0d |ectory o|wned by.|
|000002d0| 0a 23 20 79 6f 75 20 77 | 69 74 68 20 64 65 66 61 |.# you w|ith defa|
|000002e0| 75 6c 74 20 70 65 72 6d | 69 73 73 69 6f 6e 73 2e |ult perm|issions.|
|000002f0| 0d 0a 23 0d 0a 23 20 54 | 68 65 20 66 69 6c 65 73 |..#..# T|he files|
|00000300| 20 63 6f 6e 74 61 69 6e | 65 64 20 68 65 72 65 69 | contain|ed herei|
|00000310| 6e 20 61 72 65 3a 0d 0a | 23 0d 0a 23 20 2d 72 77 |n are:..|#..# -rw|
|00000320| 2d 72 2d 2d 72 2d 2d 20 | 20 31 20 68 79 63 20 20 |-r--r-- | 1 hyc |
|00000330| 20 20 20 20 20 20 20 31 | 31 35 31 34 20 4a 75 6e | 1|1514 Jun|
|00000340| 20 31 33 20 31 33 3a 35 | 34 20 61 72 63 73 71 73 | 13 13:5|4 arcsqs|
|00000350| 2e 63 0d 0a 23 20 2d 72 | 77 2d 72 2d 2d 72 2d 2d |.c..# -r|w-r--r--|
|00000360| 20 20 31 20 68 79 63 20 | 20 20 20 20 20 20 20 20 | 1 hyc | |
|00000370| 20 34 36 38 30 20 4a 75 | 6e 20 31 33 20 30 30 3a | 4680 Ju|n 13 00:|
|00000380| 34 33 20 61 72 63 73 76 | 63 2e 63 0d 0a 23 20 2d |43 arcsv|c.c..# -|
|00000390| 72 77 2d 72 2d 2d 72 2d | 2d 20 20 31 20 68 79 63 |rw-r--r-|- 1 hyc|
|000003a0| 20 20 20 20 20 20 20 20 | 20 20 31 32 38 34 20 41 | | 1284 A|
|000003b0| 70 72 20 31 39 20 30 31 | 3a 34 30 20 61 72 63 74 |pr 19 01|:40 arct|
|000003c0| 73 74 2e 63 0d 0a 23 20 | 2d 72 77 2d 72 2d 2d 72 |st.c..# |-rw-r--r|
|000003d0| 2d 2d 20 20 31 20 68 79 | 63 20 20 20 20 20 20 20 |-- 1 hy|c |
|000003e0| 20 20 20 35 33 34 37 20 | 4a 75 6e 20 31 38 20 30 | 5347 |Jun 18 0|
|000003f0| 33 3a 31 33 20 61 72 63 | 75 6e 70 2e 63 0d 0a 23 |3:13 arc|unp.c..#|
|00000400| 20 2d 72 77 2d 72 2d 2d | 72 2d 2d 20 20 31 20 68 | -rw-r--|r-- 1 h|
|00000410| 79 63 20 20 20 20 20 20 | 20 20 20 20 32 34 38 34 |yc | 2484|
|00000420| 20 4a 75 6e 20 20 32 20 | 31 36 3a 32 38 20 61 72 | Jun 2 |16:28 ar|
|00000430| 63 75 73 71 2e 63 0d 0a | 23 20 2d 72 77 2d 72 2d |cusq.c..|# -rw-r-|
|00000440| 2d 72 2d 2d 20 20 31 20 | 68 79 63 20 20 20 20 20 |-r-- 1 |hyc |
|00000450| 20 20 20 20 20 39 30 33 | 32 20 4a 75 6e 20 31 33 | 903|2 Jun 13|
|00000460| 20 31 33 3a 35 36 20 64 | 74 69 6d 65 2e 63 0d 0a | 13:56 d|time.c..|
|00000470| 23 20 2d 72 77 2d 72 2d | 2d 72 2d 2d 20 20 31 20 |# -rw-r-|-r-- 1 |
|00000480| 68 79 63 20 20 20 20 20 | 20 20 20 20 20 37 33 32 |hyc | 732|
|00000490| 37 20 41 70 72 20 31 31 | 20 31 39 3a 31 31 20 64 |7 Apr 11| 19:11 d|
|000004a0| 74 69 6d 65 70 2e 6c 65 | 78 0d 0a 23 20 2d 72 77 |timep.le|x..# -rw|
|000004b0| 2d 72 2d 2d 72 2d 2d 20 | 20 31 20 68 79 63 20 20 |-r--r-- | 1 hyc |
|000004c0| 20 20 20 20 20 20 20 20 | 20 33 35 36 20 41 70 72 | | 356 Apr|
|000004d0| 20 31 31 20 31 39 3a 31 | 32 20 6c 65 78 65 64 69 | 11 19:1|2 lexedi|
|000004e0| 74 2e 73 65 64 0d 0a 23 | 20 2d 72 77 2d 72 2d 2d |t.sed..#| -rw-r--|
|000004f0| 72 2d 2d 20 20 31 20 68 | 79 63 20 20 20 20 20 20 |r-- 1 h|yc |
|00000500| 20 20 20 20 33 37 31 33 | 20 4a 75 6e 20 31 33 20 | 3713| Jun 13 |
|00000510| 31 33 3a 35 39 20 6c 65 | 78 73 74 72 69 6e 67 2e |13:59 le|xstring.|
|00000520| 63 0d 0a 23 20 2d 72 77 | 2d 72 2d 2d 72 2d 2d 20 |c..# -rw|-r--r-- |
|00000530| 20 31 20 68 79 63 20 20 | 20 20 20 20 20 20 20 20 | 1 hyc | |
|00000540| 32 32 34 31 20 41 70 72 | 20 31 31 20 31 39 3a 31 |2241 Apr| 11 19:1|
|00000550| 33 20 6c 69 62 74 77 73 | 2e 33 0d 0a 23 20 2d 72 |3 libtws|.3..# -r|
|00000560| 77 2d 72 2d 2d 72 2d 2d | 20 20 31 20 68 79 63 20 |w-r--r--| 1 hyc |
|00000570| 20 20 20 20 20 20 20 20 | 20 39 30 35 33 20 4a 75 | | 9053 Ju|
|00000580| 6e 20 20 36 20 30 31 3a | 30 34 20 6d 61 72 63 2e |n 6 01:|04 marc.|
|00000590| 63 0d 0a 23 0d 0a 65 63 | 68 6f 20 27 78 20 2d 20 |c..#..ec|ho 'x - |
|000005a0| 61 72 63 73 71 73 2e 63 | 27 0d 0a 69 66 20 74 65 |arcsqs.c|'..if te|
|000005b0| 73 74 20 2d 66 20 61 72 | 63 73 71 73 2e 63 3b 20 |st -f ar|csqs.c; |
|000005c0| 74 68 65 6e 20 65 63 68 | 6f 20 27 73 68 61 72 3a |then ech|o 'shar:|
|000005d0| 20 6e 6f 74 20 6f 76 65 | 72 77 72 69 74 69 6e 67 | not ove|rwriting|
|000005e0| 20 61 72 63 73 71 73 2e | 63 27 3b 20 65 6c 73 65 | arcsqs.|c'; else|
|000005f0| 0d 0a 73 65 64 20 27 73 | 2f 5e 58 2f 2f 27 20 3c |..sed 's|/^X//' <|
|00000600| 3c 20 27 5f 5f 5f 5f 5f | 5f 5f 5f 54 68 69 73 5f |< '_____|___This_|
|00000610| 49 73 5f 54 68 65 5f 45 | 4e 44 5f 5f 5f 5f 5f 5f |Is_The_E|ND______|
|00000620| 5f 5f 27 20 3e 20 61 72 | 63 73 71 73 2e 63 0d 0a |__' > ar|csqs.c..|
|00000630| 58 2f 2a 0d 0a 58 20 2a | 20 24 48 65 61 64 65 72 |X/*..X *| $Header|
|00000640| 3a 20 61 72 63 73 71 73 | 2e 63 2c 76 20 31 2e 32 |: arcsqs|.c,v 1.2|
|00000650| 20 38 38 2f 30 36 2f 30 | 31 20 31 36 3a 33 31 3a | 88/06/0|1 16:31:|
|00000660| 33 39 20 68 79 63 20 4c | 6f 63 6b 65 64 20 24 0d |39 hyc L|ocked $.|
|00000670| 0a 58 20 2a 2f 0d 0a 58 | 0d 0a 58 2f 2a 20 20 41 |.X */..X|..X/* A|
|00000680| 52 43 20 2d 20 41 72 63 | 68 69 76 65 20 75 74 69 |RC - Arc|hive uti|
|00000690| 6c 69 74 79 20 2d 20 53 | 51 55 41 53 48 0d 0a 58 |lity - S|QUASH..X|
|000006a0| 20 0d 0a 58 28 43 29 20 | 43 4f 50 59 52 49 47 48 | ..X(C) |COPYRIGH|
|000006b0| 54 20 31 39 38 35 20 62 | 79 20 53 79 73 74 65 6d |T 1985 b|y System|
|000006c0| 20 45 6e 68 61 6e 63 65 | 6d 65 6e 74 20 41 73 73 | Enhance|ment Ass|
|000006d0| 6f 63 69 61 74 65 73 3b | 20 41 4c 4c 20 52 49 47 |ociates;| ALL RIG|
|000006e0| 48 54 53 20 52 45 53 45 | 52 56 45 44 0d 0a 58 20 |HTS RESE|RVED..X |
|000006f0| 0d 0a 58 20 54 68 69 73 | 20 69 73 20 61 20 71 75 |..X This| is a qu|
|00000700| 69 63 6b 20 68 61 63 6b | 20 74 6f 20 41 52 43 4c |ick hack| to ARCL|
|00000710| 5a 57 20 74 6f 20 6d 61 | 6b 65 20 69 74 20 68 61 |ZW to ma|ke it ha|
|00000720| 6e 64 6c 65 20 73 71 75 | 61 73 68 65 64 20 61 72 |ndle squ|ashed ar|
|00000730| 63 68 69 76 65 73 2e 0d | 0a 58 20 44 61 6e 20 4c |chives..|.X Dan L|
|00000740| 61 6e 63 69 61 6e 69 20 | 28 64 64 6c 40 68 61 72 |anciani |(ddl@har|
|00000750| 76 61 72 64 2e 2a 29 20 | 4a 75 6c 79 20 38 37 0d |vard.*) |July 87.|
|00000760| 0a 58 20 0d 0a 58 2a 2f | 0d 0a 58 0d 0a 58 2f 2a |.X ..X*/|..X..X/*|
|00000770| 0d 0a 58 20 2a 20 24 48 | 65 61 64 65 72 3a 20 61 |..X * $H|eader: a|
|00000780| 72 63 73 71 73 2e 63 2c | 76 20 31 2e 32 20 38 38 |rcsqs.c,|v 1.2 88|
|00000790| 2f 30 36 2f 30 31 20 31 | 36 3a 33 31 3a 33 39 20 |/06/01 1|6:31:39 |
|000007a0| 68 79 63 20 4c 6f 63 6b | 65 64 20 24 0d 0a 58 20 |hyc Lock|ed $..X |
|000007b0| 2a 2f 0d 0a 58 0d 0a 58 | 23 69 6e 63 6c 75 64 65 |*/..X..X|#include|
|000007c0| 20 3c 73 74 64 69 6f 2e | 68 3e 0d 0a 58 23 69 6e | <stdio.|h>..X#in|
|000007d0| 63 6c 75 64 65 20 22 61 | 72 63 2e 68 22 0d 0a 58 |clude "a|rc.h"..X|
|000007e0| 0d 0a 58 23 69 66 09 4d | 53 44 4f 53 0d 0a 58 63 |..X#if.M|SDOS..Xc|
|000007f0| 68 61 72 09 2a 73 65 74 | 6d 65 6d 28 29 3b 0d 0a |har.*set|mem();..|
|00000800| 58 23 65 6c 73 65 0d 0a | 58 63 68 61 72 09 2a 6d |X#else..|Xchar.*m|
|00000810| 65 6d 73 65 74 28 29 3b | 0d 0a 58 23 65 6e 64 69 |emset();|..X#endi|
|00000820| 66 0d 0a 58 69 6e 74 09 | 67 65 74 63 5f 75 6e 70 |f..Xint.|getc_unp|
|00000830| 28 29 3b 0d 0a 58 76 6f | 69 64 09 70 75 74 63 5f |();..Xvo|id.putc_|
|00000840| 70 61 6b 28 29 2c 20 70 | 75 74 63 5f 75 6e 70 28 |pak(), p|utc_unp(|
|00000850| 29 3b 0d 0a 58 73 74 61 | 74 69 63 20 76 6f 69 64 |);..Xsta|tic void|
|00000860| 09 70 75 74 63 6f 64 65 | 28 29 3b 0d 0a 58 0d 0a |.putcode|();..X..|
|00000870| 58 2f 2a 20 64 65 66 69 | 6e 69 74 69 6f 6e 73 20 |X/* defi|nitions |
|00000880| 66 6f 72 20 74 68 65 20 | 6e 65 77 20 64 79 6e 61 |for the |new dyna|
|00000890| 6d 69 63 20 4c 65 6d 70 | 65 6c 2d 5a 65 76 20 63 |mic Lemp|el-Zev c|
|000008a0| 72 75 6e 63 68 69 6e 67 | 20 2a 2f 0d 0a 58 0d 0a |runching| */..X..|
|000008b0| 58 23 64 65 66 69 6e 65 | 20 42 49 54 53 20 20 20 |X#define| BITS |
|000008c0| 31 33 09 09 2f 2a 20 6d | 61 78 69 6d 75 6d 20 62 |13../* m|aximum b|
|000008d0| 69 74 73 20 70 65 72 20 | 63 6f 64 65 20 2a 2f 0d |its per |code */.|
|000008e0| 0a 58 23 64 65 66 69 6e | 65 20 48 53 49 5a 45 20 |.X#defin|e HSIZE |
|000008f0| 20 31 30 30 30 37 09 09 | 2f 2a 20 38 30 25 20 6f | 10007..|/* 80% o|
|00000900| 63 63 75 70 61 6e 63 79 | 20 2a 2f 0d 0a 58 23 64 |ccupancy| */..X#d|
|00000910| 65 66 69 6e 65 20 49 4e | 49 54 5f 42 49 54 53 20 |efine IN|IT_BITS |
|00000920| 39 09 09 2f 2a 20 69 6e | 69 74 69 61 6c 20 6e 75 |9../* in|itial nu|
|00000930| 6d 62 65 72 20 6f 66 20 | 62 69 74 73 2f 63 6f 64 |mber of |bits/cod|
|00000940| 65 20 2a 2f 0d 0a 58 73 | 74 61 74 69 63 20 69 6e |e */..Xs|tatic in|
|00000950| 74 20 20 20 20 20 20 6e | 5f 62 69 74 73 3b 09 09 |t n|_bits;..|
|00000960| 2f 2a 20 6e 75 6d 62 65 | 72 20 6f 66 20 62 69 74 |/* numbe|r of bit|
|00000970| 73 2f 63 6f 64 65 20 2a | 2f 0d 0a 58 73 74 61 74 |s/code *|/..Xstat|
|00000980| 69 63 20 69 6e 74 20 20 | 20 20 20 20 6d 61 78 63 |ic int | maxc|
|00000990| 6f 64 65 3b 09 2f 2a 20 | 6d 61 78 69 6d 75 6d 20 |ode;./* |maximum |
|000009a0| 63 6f 64 65 2c 20 67 69 | 76 65 6e 20 6e 5f 62 69 |code, gi|ven n_bi|
|000009b0| 74 73 20 2a 2f 0d 0a 58 | 23 64 65 66 69 6e 65 20 |ts */..X|#define |
|000009c0| 4d 41 58 43 4f 44 45 28 | 6e 29 20 20 20 20 20 20 |MAXCODE(|n) |
|000009d0| 28 28 31 3c 3c 28 6e 29 | 29 20 2d 20 31 29 09 2f |((1<<(n)|) - 1)./|
|000009e0| 2a 20 6d 61 78 69 6d 75 | 6d 20 63 6f 64 65 20 63 |* maximu|m code c|
|000009f0| 61 6c 63 75 6c 61 74 69 | 6f 6e 20 2a 2f 0d 0a 58 |alculati|on */..X|
|00000a00| 73 74 61 74 69 63 20 69 | 6e 74 20 20 20 20 20 20 |static i|nt |
|00000a10| 6d 61 78 63 6f 64 65 6d | 61 78 20 3d 20 31 20 3c |maxcodem|ax = 1 <|
|00000a20| 3c 20 42 49 54 53 3b 09 | 2f 2a 20 6c 61 72 67 65 |< BITS;.|/* large|
|00000a30| 73 74 20 70 6f 73 73 69 | 62 6c 65 20 63 6f 64 65 |st possi|ble code|
|00000a40| 20 28 2b 31 29 20 2a 2f | 0d 0a 58 0d 0a 58 73 74 | (+1) */|..X..Xst|
|00000a50| 61 74 69 63 20 75 6e 73 | 69 67 6e 65 64 20 63 68 |atic uns|igned ch|
|00000a60| 61 72 20 62 75 66 5b 42 | 49 54 53 5d 3b 09 2f 2a |ar buf[B|ITS];./*|
|00000a70| 20 69 6e 70 75 74 2f 6f | 75 74 70 75 74 20 62 75 | input/o|utput bu|
|00000a80| 66 66 65 72 20 2a 2f 0d | 0a 58 0d 0a 58 73 74 61 |ffer */.|.X..Xsta|
|00000a90| 74 69 63 20 75 6e 73 69 | 67 6e 65 64 20 63 68 61 |tic unsi|gned cha|
|00000aa0| 72 20 6c 6d 61 73 6b 5b | 39 5d 20 3d 09 2f 2a 20 |r lmask[|9] =./* |
|00000ab0| 6c 65 66 74 20 73 69 64 | 65 20 6d 61 73 6b 73 20 |left sid|e masks |
|00000ac0| 2a 2f 0d 0a 58 7b 30 78 | 66 66 2c 20 30 78 66 65 |*/..X{0x|ff, 0xfe|
|00000ad0| 2c 20 30 78 66 63 2c 20 | 30 78 66 38 2c 20 30 78 |, 0xfc, |0xf8, 0x|
|00000ae0| 66 30 2c 20 30 78 65 30 | 2c 20 30 78 63 30 2c 20 |f0, 0xe0|, 0xc0, |
|00000af0| 30 78 38 30 2c 20 30 78 | 30 30 7d 3b 0d 0a 58 73 |0x80, 0x|00};..Xs|
|00000b00| 74 61 74 69 63 20 75 6e | 73 69 67 6e 65 64 20 63 |tatic un|signed c|
|00000b10| 68 61 72 20 72 6d 61 73 | 6b 5b 39 5d 20 3d 09 2f |har rmas|k[9] =./|
|00000b20| 2a 20 72 69 67 68 74 20 | 73 69 64 65 20 6d 61 73 |* right |side mas|
|00000b30| 6b 73 20 2a 2f 0d 0a 58 | 7b 30 78 30 30 2c 20 30 |ks */..X|{0x00, 0|
|00000b40| 78 30 31 2c 20 30 78 30 | 33 2c 20 30 78 30 37 2c |x01, 0x0|3, 0x07,|
|00000b50| 20 30 78 30 66 2c 20 30 | 78 31 66 2c 20 30 78 33 | 0x0f, 0|x1f, 0x3|
|00000b60| 66 2c 20 30 78 37 66 2c | 20 30 78 66 66 7d 3b 0d |f, 0x7f,| 0xff};.|
|00000b70| 0a 58 0d 0a 58 73 74 61 | 74 69 63 20 69 6e 74 20 |.X..Xsta|tic int |
|00000b80| 20 20 20 20 20 6f 66 66 | 73 65 74 3b 09 09 2f 2a | off|set;../*|
|00000b90| 20 62 79 74 65 20 6f 66 | 66 73 65 74 20 66 6f 72 | byte of|fset for|
|00000ba0| 20 63 6f 64 65 20 6f 75 | 74 70 75 74 20 2a 2f 0d | code ou|tput */.|
|00000bb0| 0a 58 73 74 61 74 69 63 | 20 6c 6f 6e 67 20 20 20 |.Xstatic| long |
|00000bc0| 20 20 69 6e 5f 63 6f 75 | 6e 74 3b 09 2f 2a 20 6c | in_cou|nt;./* l|
|00000bd0| 65 6e 67 74 68 20 6f 66 | 20 69 6e 70 75 74 20 2a |ength of| input *|
|00000be0| 2f 0d 0a 58 73 74 61 74 | 69 63 20 6c 6f 6e 67 20 |/..Xstat|ic long |
|00000bf0| 20 20 20 20 62 79 74 65 | 73 5f 6f 75 74 3b 09 2f | byte|s_out;./|
|00000c00| 2a 20 6c 65 6e 67 74 68 | 20 6f 66 20 63 6f 6d 70 |* length| of comp|
|00000c10| 72 65 73 73 65 64 20 6f | 75 74 70 75 74 20 2a 2f |ressed o|utput */|
|00000c20| 0d 0a 58 73 74 61 74 69 | 63 20 75 6e 73 69 67 6e |..Xstati|c unsign|
|00000c30| 65 64 20 73 68 6f 72 74 | 20 65 6e 74 3b 0d 0a 58 |ed short| ent;..X|
|00000c40| 0d 0a 58 6c 6f 6e 67 20 | 20 20 20 20 68 74 61 62 |..Xlong | htab|
|00000c50| 5b 48 53 49 5a 45 5d 3b | 09 2f 2a 20 68 61 73 68 |[HSIZE];|./* hash|
|00000c60| 20 63 6f 64 65 20 74 61 | 62 6c 65 20 20 20 28 63 | code ta|ble (c|
|00000c70| 72 75 6e 63 68 29 20 2a | 2f 0d 0a 58 75 6e 73 69 |runch) *|/..Xunsi|
|00000c80| 67 6e 65 64 20 73 68 6f | 72 74 20 63 6f 64 65 74 |gned sho|rt codet|
|00000c90| 61 62 5b 48 53 49 5a 45 | 5d 3b 09 2f 2a 20 73 74 |ab[HSIZE|];./* st|
|00000ca0| 72 69 6e 67 20 63 6f 64 | 65 20 74 61 62 6c 65 20 |ring cod|e table |
|00000cb0| 28 63 72 75 6e 63 68 29 | 20 2a 2f 0d 0a 58 0d 0a |(crunch)| */..X..|
|00000cc0| 58 73 74 61 74 69 63 20 | 75 6e 73 69 67 6e 65 64 |Xstatic |unsigned|
|00000cd0| 20 73 68 6f 72 74 20 2a | 70 72 65 66 69 78 20 3d | short *|prefix =|
|00000ce0| 20 63 6f 64 65 74 61 62 | 3b 20 20 2f 2a 20 70 72 | codetab|; /* pr|
|00000cf0| 65 66 69 78 20 63 6f 64 | 65 20 74 61 62 6c 65 20 |efix cod|e table |
|00000d00| 28 75 6e 63 72 75 6e 63 | 68 29 20 2a 2f 0d 0a 58 |(uncrunc|h) */..X|
|00000d10| 73 74 61 74 69 63 20 75 | 6e 73 69 67 6e 65 64 20 |static u|nsigned |
|00000d20| 63 68 61 72 20 2a 73 75 | 66 66 69 78 3d 28 75 6e |char *su|ffix=(un|
|00000d30| 73 69 67 6e 65 64 20 63 | 68 61 72 20 2a 29 68 74 |signed c|har *)ht|
|00000d40| 61 62 3b 20 20 2f 2a 20 | 73 75 66 66 69 78 20 74 |ab; /* |suffix t|
|00000d50| 61 62 6c 65 20 28 75 6e | 63 72 75 6e 63 68 29 20 |able (un|crunch) |
|00000d60| 2a 2f 0d 0a 58 73 74 61 | 74 69 63 20 69 6e 74 20 |*/..Xsta|tic int |
|00000d70| 20 20 20 20 20 66 72 65 | 65 5f 65 6e 74 3b 09 2f | fre|e_ent;./|
|00000d80| 2a 20 66 69 72 73 74 20 | 75 6e 75 73 65 64 20 65 |* first |unused e|
|00000d90| 6e 74 72 79 20 2a 2f 0d | 0a 58 73 74 61 74 69 63 |ntry */.|.Xstatic|
|00000da0| 20 69 6e 74 20 20 20 20 | 20 20 66 69 72 73 74 63 | int | firstc|
|00000db0| 6d 70 3b 09 2f 2a 20 74 | 72 75 65 20 61 74 20 73 |mp;./* t|rue at s|
|00000dc0| 74 61 72 74 20 6f 66 20 | 63 6f 6d 70 72 65 73 73 |tart of |compress|
|00000dd0| 69 6f 6e 20 2a 2f 0d 0a | 58 75 6e 73 69 67 6e 65 |ion */..|Xunsigne|
|00000de0| 64 20 63 68 61 72 20 73 | 74 61 63 6b 5b 48 53 49 |d char s|tack[HSI|
|00000df0| 5a 45 5d 3b 09 2f 2a 20 | 6c 6f 63 61 6c 20 70 75 |ZE];./* |local pu|
|00000e00| 73 68 2f 70 6f 70 20 73 | 74 61 63 6b 20 2a 2f 0d |sh/pop s|tack */.|
|00000e10| 0a 58 0d 0a 58 2f 2a 0d | 0a 58 20 2a 20 62 6c 6f |.X..X/*.|.X * blo|
|00000e20| 63 6b 20 63 6f 6d 70 72 | 65 73 73 69 6f 6e 20 70 |ck compr|ession p|
|00000e30| 61 72 61 6d 65 74 65 72 | 73 20 2d 2d 20 61 66 74 |arameter|s -- aft|
|00000e40| 65 72 20 61 6c 6c 20 63 | 6f 64 65 73 20 61 72 65 |er all c|odes are|
|00000e50| 20 75 73 65 64 20 75 70 | 2c 0d 0a 58 20 2a 20 61 | used up|,..X * a|
|00000e60| 6e 64 20 63 6f 6d 70 72 | 65 73 73 69 6f 6e 20 72 |nd compr|ession r|
|00000e70| 61 74 65 20 63 68 61 6e | 67 65 73 2c 20 73 74 61 |ate chan|ges, sta|
|00000e80| 72 74 20 6f 76 65 72 2e | 0d 0a 58 20 2a 2f 0d 0a |rt over.|..X */..|
|00000e90| 58 0d 0a 58 73 74 61 74 | 69 63 20 69 6e 74 20 20 |X..Xstat|ic int |
|00000ea0| 20 20 20 20 63 6c 65 61 | 72 5f 66 6c 67 3b 0d 0a | clea|r_flg;..|
|00000eb0| 58 73 74 61 74 69 63 20 | 6c 6f 6e 67 20 20 20 20 |Xstatic |long |
|00000ec0| 20 72 61 74 69 6f 3b 0d | 0a 58 23 64 65 66 69 6e | ratio;.|.X#defin|
|00000ed0| 65 20 43 48 45 43 4b 5f | 47 41 50 20 31 30 30 30 |e CHECK_|GAP 1000|
|00000ee0| 30 09 09 2f 2a 20 72 61 | 74 69 6f 20 63 68 65 63 |0../* ra|tio chec|
|00000ef0| 6b 20 69 6e 74 65 72 76 | 61 6c 20 2a 2f 0d 0a 58 |k interv|al */..X|
|00000f00| 73 74 61 74 69 63 20 6c | 6f 6e 67 20 20 20 20 20 |static l|ong |
|00000f10| 63 68 65 63 6b 70 6f 69 | 6e 74 3b 0d 0a 58 0d 0a |checkpoi|nt;..X..|
|00000f20| 58 2f 2a 0d 0a 58 20 2a | 20 74 68 65 20 6e 65 78 |X/*..X *| the nex|
|00000f30| 74 20 74 77 6f 20 63 6f | 64 65 73 20 73 68 6f 75 |t two co|des shou|
|00000f40| 6c 64 20 6e 6f 74 20 62 | 65 20 63 68 61 6e 67 65 |ld not b|e change|
|00000f50| 64 20 6c 69 67 68 74 6c | 79 2c 20 61 73 20 74 68 |d lightl|y, as th|
|00000f60| 65 79 20 6d 75 73 74 20 | 6e 6f 74 0d 0a 58 20 2a |ey must |not..X *|
|00000f70| 20 6c 69 65 20 77 69 74 | 68 69 6e 20 74 68 65 20 | lie wit|hin the |
|00000f80| 63 6f 6e 74 69 67 75 6f | 75 73 20 67 65 6e 65 72 |contiguo|us gener|
|00000f90| 61 6c 20 63 6f 64 65 20 | 73 70 61 63 65 2e 0d 0a |al code |space...|
|00000fa0| 58 20 2a 2f 0d 0a 58 23 | 64 65 66 69 6e 65 20 46 |X */..X#|define F|
|00000fb0| 49 52 53 54 20 20 20 32 | 35 37 09 09 2f 2a 20 66 |IRST 2|57../* f|
|00000fc0| 69 72 73 74 20 66 72 65 | 65 20 65 6e 74 72 79 20 |irst fre|e entry |
|00000fd0| 2a 2f 0d 0a 58 23 64 65 | 66 69 6e 65 20 43 4c 45 |*/..X#de|fine CLE|
|00000fe0| 41 52 20 20 20 32 35 36 | 09 09 2f 2a 20 74 61 62 |AR 256|../* tab|
|00000ff0| 6c 65 20 63 6c 65 61 72 | 20 6f 75 74 70 75 74 20 |le clear| output |
|00001000| 63 6f 64 65 20 2a 2f 0d | 0a 58 0d 0a 58 73 74 61 |code */.|.X..Xsta|
|00001010| 74 69 63 20 76 6f 69 64 | 0d 0a 58 63 6c 5f 62 6c |tic void|..Xcl_bl|
|00001020| 6f 63 6b 28 74 29 09 09 | 09 2f 2a 20 74 61 62 6c |ock(t)..|./* tabl|
|00001030| 65 20 63 6c 65 61 72 20 | 66 6f 72 20 62 6c 6f 63 |e clear |for bloc|
|00001040| 6b 20 63 6f 6d 70 72 65 | 73 73 20 2a 2f 0d 0a 58 |k compre|ss */..X|
|00001050| 09 46 49 4c 45 20 20 20 | 20 20 20 20 20 20 20 20 |.FILE | |
|00001060| 2a 74 3b 09 2f 2a 20 6f | 75 72 20 6f 75 74 70 75 |*t;./* o|ur outpu|
|00001070| 74 20 66 69 6c 65 20 2a | 2f 0d 0a 58 7b 0d 0a 58 |t file *|/..X{..X|
|00001080| 09 6c 6f 6e 67 20 20 20 | 20 20 20 20 20 20 20 20 |.long | |
|00001090| 20 72 61 74 3b 0d 0a 58 | 0d 0a 58 09 63 68 65 63 | rat;..X|..X.chec|
|000010a0| 6b 70 6f 69 6e 74 20 3d | 20 69 6e 5f 63 6f 75 6e |kpoint =| in_coun|
|000010b0| 74 20 2b 20 43 48 45 43 | 4b 5f 47 41 50 3b 0d 0a |t + CHEC|K_GAP;..|
|000010c0| 58 0d 0a 58 09 69 66 20 | 28 69 6e 5f 63 6f 75 6e |X..X.if |(in_coun|
|000010d0| 74 20 3e 20 30 78 30 30 | 37 66 66 66 66 66 4c 29 |t > 0x00|7fffffL)|
|000010e0| 20 7b 09 2f 2a 20 73 68 | 69 66 74 20 77 69 6c 6c | {./* sh|ift will|
|000010f0| 20 6f 76 65 72 66 6c 6f | 77 20 2a 2f 0d 0a 58 09 | overflo|w */..X.|
|00001100| 09 72 61 74 20 3d 20 62 | 79 74 65 73 5f 6f 75 74 |.rat = b|ytes_out|
|00001110| 20 3e 3e 20 38 3b 0d 0a | 58 09 09 69 66 20 28 72 | >> 8;..|X..if (r|
|00001120| 61 74 20 3d 3d 20 30 29 | 09 2f 2a 20 44 6f 6e 27 |at == 0)|./* Don'|
|00001130| 74 20 64 69 76 69 64 65 | 20 62 79 20 7a 65 72 6f |t divide| by zero|
|00001140| 20 2a 2f 0d 0a 58 09 09 | 09 72 61 74 20 3d 20 30 | */..X..|.rat = 0|
|00001150| 78 37 66 66 66 66 66 66 | 66 4c 3b 0d 0a 58 09 09 |x7ffffff|fL;..X..|
|00001160| 65 6c 73 65 0d 0a 58 09 | 09 09 72 61 74 20 3d 20 |else..X.|..rat = |
|00001170| 69 6e 5f 63 6f 75 6e 74 | 20 2f 20 72 61 74 3b 0d |in_count| / rat;.|
|00001180| 0a 58 09 7d 20 65 6c 73 | 65 0d 0a 58 09 09 72 61 |.X.} els|e..X..ra|
|00001190| 74 20 3d 20 28 69 6e 5f | 63 6f 75 6e 74 20 3c 3c |t = (in_|count <<|
|000011a0| 20 38 29 20 2f 20 62 79 | 74 65 73 5f 6f 75 74 3b | 8) / by|tes_out;|
|000011b0| 09 2f 2a 20 38 20 66 72 | 61 63 74 69 6f 6e 61 6c |./* 8 fr|actional|
|000011c0| 20 62 69 74 73 20 2a 2f | 0d 0a 58 0d 0a 58 09 69 | bits */|..X..X.i|
|000011d0| 66 20 28 72 61 74 20 3e | 20 72 61 74 69 6f 29 0d |f (rat >| ratio).|
|000011e0| 0a 58 09 09 72 61 74 69 | 6f 20 3d 20 72 61 74 3b |.X..rati|o = rat;|
|000011f0| 0d 0a 58 09 65 6c 73 65 | 20 7b 0d 0a 58 09 09 72 |..X.else| {..X..r|
|00001200| 61 74 69 6f 20 3d 20 30 | 3b 0d 0a 58 09 09 73 65 |atio = 0|;..X..se|
|00001210| 74 6d 65 6d 28 68 74 61 | 62 2c 20 48 53 49 5a 45 |tmem(hta|b, HSIZE|
|00001220| 20 2a 20 73 69 7a 65 6f | 66 28 6c 6f 6e 67 29 2c | * sizeo|f(long),|
|00001230| 20 30 78 66 66 29 3b 0d | 0a 58 09 09 66 72 65 65 | 0xff);.|.X..free|
|00001240| 5f 65 6e 74 20 3d 20 46 | 49 52 53 54 3b 0d 0a 58 |_ent = F|IRST;..X|
|00001250| 09 09 63 6c 65 61 72 5f | 66 6c 67 20 3d 20 31 3b |..clear_|flg = 1;|
|00001260| 0d 0a 58 09 09 70 75 74 | 63 6f 64 65 28 43 4c 45 |..X..put|code(CLE|
|00001270| 41 52 2c 20 74 29 3b 0d | 0a 58 09 7d 0d 0a 58 7d |AR, t);.|.X.}..X}|
|00001280| 0d 0a 58 0d 0a 58 2f 2a | 2a 2a 2a 2a 2a 2a 2a 2a |..X..X/*|********|
|00001290| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000012a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000012b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000012c0| 2a 2a 2a 2a 2a 2a 2a 2a | 0d 0a 58 20 2a 0d 0a 58 |********|..X *..X|
|000012d0| 20 2a 20 4f 75 74 70 75 | 74 20 61 20 67 69 76 65 | * Outpu|t a give|
|000012e0| 6e 20 63 6f 64 65 2e 0d | 0a 58 20 2a 20 49 6e 70 |n code..|.X * Inp|
|000012f0| 75 74 73 3a 0d 0a 58 20 | 2a 20 20 20 20 20 20 63 |uts:..X |* c|
|00001300| 6f 64 65 3a 20 20 20 41 | 20 6e 5f 62 69 74 73 2d |ode: A| n_bits-|
|00001310| 62 69 74 20 69 6e 74 65 | 67 65 72 2e 20 20 49 66 |bit inte|ger. If|
|00001320| 20 3d 3d 20 2d 31 2c 20 | 74 68 65 6e 20 45 4f 46 | == -1, |then EOF|
|00001330| 2e 20 20 54 68 69 73 20 | 61 73 73 75 6d 65 73 0d |. This |assumes.|
|00001340| 0a 58 20 2a 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X * | |
|00001350| 20 20 74 68 61 74 20 6e | 5f 62 69 74 73 20 3d 3c | that n|_bits =<|
|00001360| 20 28 6c 6f 6e 67 29 77 | 6f 72 64 73 69 7a 65 20 | (long)w|ordsize |
|00001370| 2d 20 31 2e 0d 0a 58 20 | 2a 20 4f 75 74 70 75 74 |- 1...X |* Output|
|00001380| 73 3a 0d 0a 58 20 2a 20 | 20 20 20 20 20 4f 75 74 |s:..X * | Out|
|00001390| 70 75 74 73 20 63 6f 64 | 65 20 74 6f 20 74 68 65 |puts cod|e to the|
|000013a0| 20 66 69 6c 65 2e 0d 0a | 58 20 2a 20 41 73 73 75 | file...|X * Assu|
|000013b0| 6d 70 74 69 6f 6e 73 3a | 0d 0a 58 20 2a 20 20 20 |mptions:|..X * |
|000013c0| 20 20 20 43 68 61 72 73 | 20 61 72 65 20 38 20 62 | Chars| are 8 b|
|000013d0| 69 74 73 20 6c 6f 6e 67 | 2e 0d 0a 58 20 2a 20 41 |its long|...X * A|
|000013e0| 6c 67 6f 72 69 74 68 6d | 3a 0d 0a 58 20 2a 20 20 |lgorithm|:..X * |
|000013f0| 20 20 20 20 4d 61 69 6e | 74 61 69 6e 20 61 20 42 | Main|tain a B|
|00001400| 49 54 53 20 63 68 61 72 | 61 63 74 65 72 20 6c 6f |ITS char|acter lo|
|00001410| 6e 67 20 62 75 66 66 65 | 72 20 28 73 6f 20 74 68 |ng buffe|r (so th|
|00001420| 61 74 20 38 20 63 6f 64 | 65 73 20 77 69 6c 6c 0d |at 8 cod|es will.|
|00001430| 0a 58 20 2a 20 66 69 74 | 20 69 6e 20 69 74 20 65 |.X * fit| in it e|
|00001440| 78 61 63 74 6c 79 29 2e | 20 20 57 68 65 6e 20 74 |xactly).| When t|
|00001450| 68 65 20 62 75 66 66 65 | 72 20 66 69 6c 6c 73 20 |he buffe|r fills |
|00001460| 75 70 20 65 6d 70 74 79 | 20 69 74 20 61 6e 64 20 |up empty| it and |
|00001470| 73 74 61 72 74 20 6f 76 | 65 72 2e 0d 0a 58 20 2a |start ov|er...X *|
|00001480| 2f 0d 0a 58 0d 0a 58 73 | 74 61 74 69 63 20 76 6f |/..X..Xs|tatic vo|
|00001490| 69 64 0d 0a 58 70 75 74 | 63 6f 64 65 28 63 6f 64 |id..Xput|code(cod|
|000014a0| 65 2c 20 74 29 09 09 2f | 2a 20 6f 75 74 70 75 74 |e, t)../|* output|
|000014b0| 20 61 20 63 6f 64 65 20 | 2a 2f 0d 0a 58 09 69 6e | a code |*/..X.in|
|000014c0| 74 20 20 20 20 20 20 20 | 20 20 20 20 20 20 63 6f |t | co|
|000014d0| 64 65 3b 09 2f 2a 20 63 | 6f 64 65 20 74 6f 20 6f |de;./* c|ode to o|
|000014e0| 75 74 70 75 74 20 2a 2f | 0d 0a 58 09 46 49 4c 45 |utput */|..X.FILE|
|000014f0| 20 20 20 20 20 20 20 20 | 20 20 20 2a 74 3b 09 2f | | *t;./|
|00001500| 2a 20 77 68 65 72 65 20 | 74 6f 20 70 75 74 20 69 |* where |to put i|
|00001510| 74 20 2a 2f 0d 0a 58 7b | 0d 0a 58 09 69 6e 74 20 |t */..X{|..X.int |
|00001520| 20 20 20 20 20 20 20 20 | 20 20 20 20 72 5f 6f 66 | | r_of|
|00001530| 66 20 3d 20 6f 66 66 73 | 65 74 3b 09 2f 2a 20 72 |f = offs|et;./* r|
|00001540| 69 67 68 74 20 6f 66 66 | 73 65 74 20 2a 2f 0d 0a |ight off|set */..|
|00001550| 58 09 69 6e 74 20 20 20 | 20 20 20 20 20 20 20 20 |X.int | |
|00001560| 20 20 62 69 74 73 20 3d | 20 6e 5f 62 69 74 73 3b | bits =| n_bits;|
|00001570| 09 2f 2a 20 62 69 74 73 | 20 74 6f 20 67 6f 20 2a |./* bits| to go *|
|00001580| 2f 0d 0a 58 09 75 6e 73 | 69 67 6e 65 64 20 63 68 |/..X.uns|igned ch|
|00001590| 61 72 20 20 2a 62 70 20 | 3d 20 62 75 66 3b 09 2f |ar *bp |= buf;./|
|000015a0| 2a 20 62 75 66 66 65 72 | 20 70 6f 69 6e 74 65 72 |* buffer| pointer|
|000015b0| 20 2a 2f 0d 0a 58 09 69 | 6e 74 20 20 20 20 20 20 | */..X.i|nt |
|000015c0| 20 20 20 20 20 20 20 6e | 3b 09 2f 2a 20 69 6e 64 | n|;./* ind|
|000015d0| 65 78 20 2a 2f 0d 0a 58 | 09 72 65 67 69 73 74 65 |ex */..X|.registe|
|000015e0| 72 20 69 6e 74 09 7a 74 | 6d 70 3b 0d 0a 58 0d 0a |r int.zt|mp;..X..|
|000015f0| 58 09 69 66 20 28 63 6f | 64 65 20 3e 3d 20 30 29 |X.if (co|de >= 0)|
|00001600| 20 7b 09 2f 2a 20 69 66 | 20 61 20 72 65 61 6c 20 | {./* if| a real |
|00001610| 63 6f 64 65 20 2a 2f 2f | 2a 20 47 65 74 20 74 6f |code *//|* Get to|
|00001620| 20 74 68 65 20 66 69 72 | 73 74 20 62 79 74 65 2e | the fir|st byte.|
|00001630| 20 2a 2f 0d 0a 58 09 09 | 62 70 20 2b 3d 20 28 72 | */..X..|bp += (r|
|00001640| 5f 6f 66 66 20 3e 3e 20 | 33 29 3b 0d 0a 58 09 09 |_off >> |3);..X..|
|00001650| 72 5f 6f 66 66 20 26 3d | 20 37 3b 0d 0a 58 0d 0a |r_off &=| 7;..X..|
|00001660| 58 09 09 2f 2a 0d 0a 58 | 09 09 20 2a 20 53 69 6e |X../*..X|.. * Sin|
|00001670| 63 65 20 63 6f 64 65 20 | 69 73 20 61 6c 77 61 79 |ce code |is alway|
|00001680| 73 20 3e 3d 20 38 20 62 | 69 74 73 2c 20 6f 6e 6c |s >= 8 b|its, onl|
|00001690| 79 20 6e 65 65 64 20 74 | 6f 20 6d 61 73 6b 20 74 |y need t|o mask t|
|000016a0| 68 65 0d 0a 58 09 09 20 | 2a 20 66 69 72 73 74 20 |he..X.. |* first |
|000016b0| 68 75 6e 6b 20 6f 6e 20 | 74 68 65 20 6c 65 66 74 |hunk on |the left|
|000016c0| 2e 20 0d 0a 58 09 09 20 | 2a 2f 0d 0a 58 09 09 7a |. ..X.. |*/..X..z|
|000016d0| 74 6d 70 20 3d 20 28 63 | 6f 64 65 20 3c 3c 20 72 |tmp = (c|ode << r|
|000016e0| 5f 6f 66 66 29 20 26 20 | 6c 6d 61 73 6b 5b 72 5f |_off) & |lmask[r_|
|000016f0| 6f 66 66 5d 3b 0d 0a 58 | 09 09 2a 62 70 20 3d 20 |off];..X|..*bp = |
|00001700| 28 2a 62 70 20 26 20 72 | 6d 61 73 6b 5b 72 5f 6f |(*bp & r|mask[r_o|
|00001710| 66 66 5d 29 20 7c 20 7a | 74 6d 70 3b 0d 0a 58 09 |ff]) | z|tmp;..X.|
|00001720| 09 62 70 2b 2b 3b 0d 0a | 58 09 09 62 69 74 73 20 |.bp++;..|X..bits |
|00001730| 2d 3d 20 28 38 20 2d 20 | 72 5f 6f 66 66 29 3b 0d |-= (8 - |r_off);.|
|00001740| 0a 58 09 09 63 6f 64 65 | 20 3e 3e 3d 20 28 38 20 |.X..code| >>= (8 |
|00001750| 2d 20 72 5f 6f 66 66 29 | 3b 0d 0a 58 0d 0a 58 09 |- r_off)|;..X..X.|
|00001760| 09 2f 2a 20 47 65 74 20 | 61 6e 79 20 38 20 62 69 |./* Get |any 8 bi|
|00001770| 74 20 70 61 72 74 73 20 | 69 6e 20 74 68 65 20 6d |t parts |in the m|
|00001780| 69 64 64 6c 65 20 28 3c | 3d 31 20 66 6f 72 20 75 |iddle (<|=1 for u|
|00001790| 70 20 74 6f 20 31 36 20 | 62 69 74 73 29 2e 20 2a |p to 16 |bits). *|
|000017a0| 2f 0d 0a 58 09 09 69 66 | 20 28 62 69 74 73 20 3e |/..X..if| (bits >|
|000017b0| 3d 20 38 29 20 7b 0d 0a | 58 09 09 09 2a 62 70 2b |= 8) {..|X...*bp+|
|000017c0| 2b 20 3d 20 63 6f 64 65 | 3b 0d 0a 58 09 09 09 63 |+ = code|;..X...c|
|000017d0| 6f 64 65 20 3e 3e 3d 20 | 38 3b 0d 0a 58 09 09 09 |ode >>= |8;..X...|
|000017e0| 62 69 74 73 20 2d 3d 20 | 38 3b 0d 0a 58 09 09 7d |bits -= |8;..X..}|
|000017f0| 0d 0a 58 09 09 2f 2a 20 | 4c 61 73 74 20 62 69 74 |..X../* |Last bit|
|00001800| 73 2e 20 2a 2f 0d 0a 58 | 09 09 69 66 20 28 62 69 |s. */..X|..if (bi|
|00001810| 74 73 29 0d 0a 58 09 09 | 09 2a 62 70 20 3d 20 63 |ts)..X..|.*bp = c|
|00001820| 6f 64 65 3b 0d 0a 58 0d | 0a 58 09 09 6f 66 66 73 |ode;..X.|.X..offs|
|00001830| 65 74 20 2b 3d 20 6e 5f | 62 69 74 73 3b 0d 0a 58 |et += n_|bits;..X|
|00001840| 0d 0a 58 09 09 69 66 20 | 28 6f 66 66 73 65 74 20 |..X..if |(offset |
|00001850| 3d 3d 20 28 6e 5f 62 69 | 74 73 20 3c 3c 20 33 29 |== (n_bi|ts << 3)|
|00001860| 29 20 7b 0d 0a 58 09 09 | 09 62 70 20 3d 20 62 75 |) {..X..|.bp = bu|
|00001870| 66 3b 0d 0a 58 09 09 09 | 62 69 74 73 20 3d 20 6e |f;..X...|bits = n|
|00001880| 5f 62 69 74 73 3b 0d 0a | 58 09 09 09 62 79 74 65 |_bits;..|X...byte|
|00001890| 73 5f 6f 75 74 20 2b 3d | 20 62 69 74 73 3b 0d 0a |s_out +=| bits;..|
|000018a0| 58 09 09 09 64 6f 0d 0a | 58 09 09 09 09 70 75 74 |X...do..|X....put|
|000018b0| 63 5f 70 61 6b 28 2a 62 | 70 2b 2b 2c 20 74 29 3b |c_pak(*b|p++, t);|
|000018c0| 0d 0a 58 09 09 09 77 68 | 69 6c 65 20 28 2d 2d 62 |..X...wh|ile (--b|
|000018d0| 69 74 73 29 3b 0d 0a 58 | 09 09 09 6f 66 66 73 65 |its);..X|...offse|
|000018e0| 74 20 3d 20 30 3b 0d 0a | 58 09 09 7d 0d 0a 58 09 |t = 0;..|X..}..X.|
|000018f0| 09 2f 2a 0d 0a 58 09 09 | 20 2a 20 49 66 20 74 68 |./*..X..| * If th|
|00001900| 65 20 6e 65 78 74 20 65 | 6e 74 72 79 20 69 73 20 |e next e|ntry is |
|00001910| 67 6f 69 6e 67 20 74 6f | 20 62 65 20 74 6f 6f 20 |going to| be too |
|00001920| 62 69 67 20 66 6f 72 20 | 74 68 65 20 63 6f 64 65 |big for |the code|
|00001930| 0d 0a 58 09 09 20 2a 20 | 73 69 7a 65 2c 20 74 68 |..X.. * |size, th|
|00001940| 65 6e 20 69 6e 63 72 65 | 61 73 65 20 69 74 2c 20 |en incre|ase it, |
|00001950| 69 66 20 70 6f 73 73 69 | 62 6c 65 2e 20 0d 0a 58 |if possi|ble. ..X|
|00001960| 09 09 20 2a 2f 0d 0a 58 | 09 09 69 66 20 28 66 72 |.. */..X|..if (fr|
|00001970| 65 65 5f 65 6e 74 20 3e | 20 6d 61 78 63 6f 64 65 |ee_ent >| maxcode|
|00001980| 20 7c 7c 20 63 6c 65 61 | 72 5f 66 6c 67 20 3e 20 | || clea|r_flg > |
|00001990| 30 29 20 7b 09 2f 2a 20 | 57 72 69 74 65 20 74 68 |0) {./* |Write th|
|000019a0| 65 20 77 68 6f 6c 65 0d | 0a 58 09 09 09 09 09 09 |e whole.|.X......|
|000019b0| 09 09 20 2a 20 62 75 66 | 66 65 72 2c 20 62 65 63 |.. * buf|fer, bec|
|000019c0| 61 75 73 65 20 74 68 65 | 0d 0a 58 09 09 09 09 09 |ause the|..X.....|
|000019d0| 09 09 09 20 2a 20 69 6e | 70 75 74 20 73 69 64 65 |... * in|put side|
|000019e0| 20 77 6f 6e 27 74 0d 0a | 58 09 09 09 09 09 09 09 | won't..|X.......|
|000019f0| 09 20 2a 20 64 69 73 63 | 6f 76 65 72 20 74 68 65 |. * disc|over the|
|00001a00| 20 73 69 7a 65 0d 0a 58 | 09 09 09 09 09 09 09 09 | size..X|........|
|00001a10| 20 2a 20 69 6e 63 72 65 | 61 73 65 20 75 6e 74 69 | * incre|ase unti|
|00001a20| 6c 20 61 66 74 65 72 0d | 0a 58 09 09 09 09 09 09 |l after.|.X......|
|00001a30| 09 09 20 2a 20 69 74 20 | 68 61 73 20 72 65 61 64 |.. * it |has read|
|00001a40| 20 69 74 2e 20 2a 2f 0d | 0a 58 09 09 09 69 66 20 | it. */.|.X...if |
|00001a50| 28 6f 66 66 73 65 74 20 | 3e 20 30 29 20 7b 0d 0a |(offset |> 0) {..|
|00001a60| 58 09 09 09 09 62 70 20 | 3d 20 62 75 66 3b 09 2f |X....bp |= buf;./|
|00001a70| 2a 20 72 65 73 65 74 20 | 70 6f 69 6e 74 65 72 20 |* reset |pointer |
|00001a80| 66 6f 72 20 77 72 69 74 | 69 6e 67 20 2a 2f 0d 0a |for writ|ing */..|
|00001a90| 58 09 09 09 09 62 79 74 | 65 73 5f 6f 75 74 20 2b |X....byt|es_out +|
|00001aa0| 3d 20 6e 20 3d 20 6e 5f | 62 69 74 73 3b 0d 0a 58 |= n = n_|bits;..X|
|00001ab0| 09 09 09 09 77 68 69 6c | 65 20 28 6e 2d 2d 29 0d |....whil|e (n--).|
|00001ac0| 0a 58 09 09 09 09 09 70 | 75 74 63 5f 70 61 6b 28 |.X.....p|utc_pak(|
|00001ad0| 2a 62 70 2b 2b 2c 20 74 | 29 3b 0d 0a 58 09 09 09 |*bp++, t|);..X...|
|00001ae0| 7d 0d 0a 58 09 09 09 6f | 66 66 73 65 74 20 3d 20 |}..X...o|ffset = |
|00001af0| 30 3b 0d 0a 58 0d 0a 58 | 09 09 09 69 66 20 28 63 |0;..X..X|...if (c|
|00001b00| 6c 65 61 72 5f 66 6c 67 | 29 20 7b 09 2f 2a 20 72 |lear_flg|) {./* r|
|00001b10| 65 73 65 74 20 69 66 20 | 63 6c 65 61 72 69 6e 67 |eset if |clearing|
|00001b20| 20 2a 2f 0d 0a 58 09 09 | 09 09 6d 61 78 63 6f 64 | */..X..|..maxcod|
|00001b30| 65 20 3d 20 4d 41 58 43 | 4f 44 45 28 6e 5f 62 69 |e = MAXC|ODE(n_bi|
|00001b40| 74 73 20 3d 20 49 4e 49 | 54 5f 42 49 54 53 29 3b |ts = INI|T_BITS);|
|00001b50| 0d 0a 58 09 09 09 09 63 | 6c 65 61 72 5f 66 6c 67 |..X....c|lear_flg|
|00001b60| 20 3d 20 30 3b 0d 0a 58 | 09 09 09 7d 20 65 6c 73 | = 0;..X|...} els|
|00001b70| 65 20 7b 2f 2a 20 65 6c | 73 65 20 75 73 65 20 6d |e {/* el|se use m|
|00001b80| 6f 72 65 20 62 69 74 73 | 20 2a 2f 0d 0a 58 09 09 |ore bits| */..X..|
|00001b90| 09 09 6e 5f 62 69 74 73 | 2b 2b 3b 0d 0a 58 09 09 |..n_bits|++;..X..|
|00001ba0| 09 09 69 66 20 28 6e 5f | 62 69 74 73 20 3d 3d 20 |..if (n_|bits == |
|00001bb0| 42 49 54 53 29 0d 0a 58 | 09 09 09 09 09 6d 61 78 |BITS)..X|.....max|
|00001bc0| 63 6f 64 65 20 3d 20 6d | 61 78 63 6f 64 65 6d 61 |code = m|axcodema|
|00001bd0| 78 3b 0d 0a 58 09 09 09 | 09 65 6c 73 65 0d 0a 58 |x;..X...|.else..X|
|00001be0| 09 09 09 09 09 6d 61 78 | 63 6f 64 65 20 3d 20 4d |.....max|code = M|
|00001bf0| 41 58 43 4f 44 45 28 6e | 5f 62 69 74 73 29 3b 0d |AXCODE(n|_bits);.|
|00001c00| 0a 58 09 09 09 7d 0d 0a | 58 09 09 7d 0d 0a 58 09 |.X...}..|X..}..X.|
|00001c10| 7d 20 65 6c 73 65 20 7b | 09 09 2f 2a 20 64 75 6d |} else {|../* dum|
|00001c20| 70 20 74 68 65 20 62 75 | 66 66 65 72 20 6f 6e 20 |p the bu|ffer on |
|00001c30| 45 4f 46 20 2a 2f 0d 0a | 58 09 09 62 79 74 65 73 |EOF */..|X..bytes|
|00001c40| 5f 6f 75 74 20 2b 3d 20 | 6e 20 3d 20 28 6f 66 66 |_out += |n = (off|
|00001c50| 73 65 74 20 2b 20 37 29 | 20 2f 20 38 3b 0d 0a 58 |set + 7)| / 8;..X|
|00001c60| 0d 0a 58 09 09 69 66 20 | 28 6f 66 66 73 65 74 20 |..X..if |(offset |
|00001c70| 3e 20 30 29 0d 0a 58 09 | 09 09 77 68 69 6c 65 20 |> 0)..X.|..while |
|00001c80| 28 6e 2d 2d 29 0d 0a 58 | 09 09 09 09 70 75 74 63 |(n--)..X|....putc|
|00001c90| 5f 70 61 6b 28 2a 62 70 | 2b 2b 2c 20 74 29 3b 0d |_pak(*bp|++, t);.|
|00001ca0| 0a 58 09 09 6f 66 66 73 | 65 74 20 3d 20 30 3b 0d |.X..offs|et = 0;.|
|00001cb0| 0a 58 09 7d 0d 0a 58 7d | 0d 0a 58 0d 0a 58 2f 2a |.X.}..X}|..X..X/*|
|00001cc0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001cd0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001ce0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001cf0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00001d00| 0d 0a 58 20 2a 0d 0a 58 | 20 2a 20 52 65 61 64 20 |..X *..X| * Read |
|00001d10| 6f 6e 65 20 63 6f 64 65 | 20 66 72 6f 6d 20 74 68 |one code| from th|
|00001d20| 65 20 73 74 61 6e 64 61 | 72 64 20 69 6e 70 75 74 |e standa|rd input|
|00001d30| 2e 20 20 49 66 20 45 4f | 46 2c 20 72 65 74 75 72 |. If EO|F, retur|
|00001d40| 6e 20 2d 31 2e 0d 0a 58 | 20 2a 20 49 6e 70 75 74 |n -1...X| * Input|
|00001d50| 73 3a 0d 0a 58 20 2a 20 | 20 20 20 20 20 63 6d 70 |s:..X * | cmp|
|00001d60| 69 6e 0d 0a 58 20 2a 20 | 4f 75 74 70 75 74 73 3a |in..X * |Outputs:|
|00001d70| 0d 0a 58 20 2a 20 20 20 | 20 20 20 63 6f 64 65 20 |..X * | code |
|00001d80| 6f 72 20 2d 31 20 69 73 | 20 72 65 74 75 72 6e 65 |or -1 is| returne|
|00001d90| 64 2e 0d 0a 58 20 2a 2f | 0d 0a 58 0d 0a 58 73 74 |d...X */|..X..Xst|
|00001da0| 61 74 69 63 20 69 6e 74 | 0d 0a 58 67 65 74 63 6f |atic int|..Xgetco|
|00001db0| 64 65 28 66 29 09 09 09 | 2f 2a 20 67 65 74 20 61 |de(f)...|/* get a|
|00001dc0| 20 63 6f 64 65 20 2a 2f | 0d 0a 58 09 46 49 4c 45 | code */|..X.FILE|
|00001dd0| 20 20 20 20 20 20 20 20 | 20 20 20 2a 66 3b 09 2f | | *f;./|
|00001de0| 2a 20 66 69 6c 65 20 74 | 6f 20 67 65 74 20 66 72 |* file t|o get fr|
|00001df0| 6f 6d 20 2a 2f 0d 0a 58 | 7b 0d 0a 58 09 69 6e 74 |om */..X|{..X.int|
|00001e00| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 63 6f 64 | | cod|
|00001e10| 65 3b 0d 0a 58 09 73 74 | 61 74 69 63 20 69 6e 74 |e;..X.st|atic int|
|00001e20| 20 20 20 20 20 20 6f 66 | 66 73 65 74 20 3d 20 30 | of|fset = 0|
|00001e30| 2c 20 73 69 7a 65 20 3d | 20 30 3b 0d 0a 58 09 69 |, size =| 0;..X.i|
|00001e40| 6e 74 20 20 20 20 20 20 | 20 20 20 20 20 20 20 72 |nt | r|
|00001e50| 5f 6f 66 66 2c 20 62 69 | 74 73 3b 0d 0a 58 09 75 |_off, bi|ts;..X.u|
|00001e60| 6e 73 69 67 6e 65 64 20 | 63 68 61 72 20 20 2a 62 |nsigned |char *b|
|00001e70| 70 20 3d 20 62 75 66 3b | 0d 0a 58 0d 0a 58 09 69 |p = buf;|..X..X.i|
|00001e80| 66 20 28 63 6c 65 61 72 | 5f 66 6c 67 20 3e 20 30 |f (clear|_flg > 0|
|00001e90| 20 7c 7c 20 6f 66 66 73 | 65 74 20 3e 3d 20 73 69 | || offs|et >= si|
|00001ea0| 7a 65 20 7c 7c 20 66 72 | 65 65 5f 65 6e 74 20 3e |ze || fr|ee_ent >|
|00001eb0| 20 6d 61 78 63 6f 64 65 | 29 20 7b 0d 0a 58 09 09 | maxcode|) {..X..|
|00001ec0| 2f 2a 20 49 66 20 74 68 | 65 20 6e 65 78 74 20 65 |/* If th|e next e|
|00001ed0| 6e 74 72 79 20 77 69 6c | 6c 20 62 65 20 74 6f 6f |ntry wil|l be too|
|00001ee0| 20 62 69 67 20 66 6f 72 | 20 74 68 65 20 63 75 72 | big for| the cur|
|00001ef0| 72 65 6e 74 20 63 6f 64 | 65 0d 0a 58 09 09 20 2a |rent cod|e..X.. *|
|00001f00| 20 73 69 7a 65 2c 20 74 | 68 65 6e 20 77 65 20 6d | size, t|hen we m|
|00001f10| 75 73 74 20 69 6e 63 72 | 65 61 73 65 20 74 68 65 |ust incr|ease the|
|00001f20| 20 73 69 7a 65 2e 20 54 | 68 69 73 20 69 6d 70 6c | size. T|his impl|
|00001f30| 69 65 73 20 72 65 61 64 | 69 6e 67 0d 0a 58 09 09 |ies read|ing..X..|
|00001f40| 20 2a 20 61 20 6e 65 77 | 20 62 75 66 66 65 72 20 | * a new| buffer |
|00001f50| 66 75 6c 6c 2c 20 74 6f | 6f 2e 20 2a 2f 0d 0a 58 |full, to|o. */..X|
|00001f60| 09 09 69 66 20 28 66 72 | 65 65 5f 65 6e 74 20 3e |..if (fr|ee_ent >|
|00001f70| 20 6d 61 78 63 6f 64 65 | 29 20 7b 0d 0a 58 09 09 | maxcode|) {..X..|
|00001f80| 09 6e 5f 62 69 74 73 2b | 2b 3b 0d 0a 58 09 09 09 |.n_bits+|+;..X...|
|00001f90| 69 66 20 28 6e 5f 62 69 | 74 73 20 3d 3d 20 42 49 |if (n_bi|ts == BI|
|00001fa0| 54 53 29 0d 0a 58 09 09 | 09 09 6d 61 78 63 6f 64 |TS)..X..|..maxcod|
|00001fb0| 65 20 3d 20 6d 61 78 63 | 6f 64 65 6d 61 78 3b 09 |e = maxc|odemax;.|
|00001fc0| 2f 2a 20 77 6f 6e 27 74 | 20 67 65 74 20 61 6e 79 |/* won't| get any|
|00001fd0| 20 62 69 67 67 65 72 0d | 0a 58 09 09 09 09 09 09 | bigger.|.X......|
|00001fe0| 09 20 2a 20 6e 6f 77 20 | 2a 2f 0d 0a 58 09 09 09 |. * now |*/..X...|
|00001ff0| 65 6c 73 65 0d 0a 58 09 | 09 09 09 6d 61 78 63 6f |else..X.|...maxco|
|00002000| 64 65 20 3d 20 4d 41 58 | 43 4f 44 45 28 6e 5f 62 |de = MAX|CODE(n_b|
|00002010| 69 74 73 29 3b 0d 0a 58 | 09 09 7d 0d 0a 58 09 09 |its);..X|..}..X..|
|00002020| 69 66 20 28 63 6c 65 61 | 72 5f 66 6c 67 20 3e 20 |if (clea|r_flg > |
|00002030| 30 29 20 7b 0d 0a 58 09 | 09 09 6d 61 78 63 6f 64 |0) {..X.|..maxcod|
|00002040| 65 20 3d 20 4d 41 58 43 | 4f 44 45 28 6e 5f 62 69 |e = MAXC|ODE(n_bi|
|00002050| 74 73 20 3d 20 49 4e 49 | 54 5f 42 49 54 53 29 3b |ts = INI|T_BITS);|
|00002060| 0d 0a 58 09 09 09 63 6c | 65 61 72 5f 66 6c 67 20 |..X...cl|ear_flg |
|00002070| 3d 20 30 3b 0d 0a 58 09 | 09 7d 0d 0a 58 09 09 66 |= 0;..X.|.}..X..f|
|00002080| 6f 72 20 28 73 69 7a 65 | 20 3d 20 30 3b 20 73 69 |or (size| = 0; si|
|00002090| 7a 65 20 3c 20 6e 5f 62 | 69 74 73 3b 20 73 69 7a |ze < n_b|its; siz|
|000020a0| 65 2b 2b 29 20 7b 0d 0a | 58 09 09 09 69 66 20 28 |e++) {..|X...if (|
|000020b0| 28 63 6f 64 65 20 3d 20 | 67 65 74 63 5f 75 6e 70 |(code = |getc_unp|
|000020c0| 28 66 29 29 20 3d 3d 20 | 45 4f 46 29 0d 0a 58 09 |(f)) == |EOF)..X.|
|000020d0| 09 09 09 62 72 65 61 6b | 3b 0d 0a 58 09 09 09 65 |...break|;..X...e|
|000020e0| 6c 73 65 0d 0a 58 09 09 | 09 09 62 75 66 5b 73 69 |lse..X..|..buf[si|
|000020f0| 7a 65 5d 20 3d 20 63 6f | 64 65 3b 0d 0a 58 09 09 |ze] = co|de;..X..|
|00002100| 7d 0d 0a 58 09 09 69 66 | 20 28 73 69 7a 65 20 3c |}..X..if| (size <|
|00002110| 3d 20 30 29 0d 0a 58 09 | 09 09 72 65 74 75 72 6e |= 0)..X.|..return|
|00002120| 20 2d 31 3b 09 2f 2a 20 | 65 6e 64 20 6f 66 20 66 | -1;./* |end of f|
|00002130| 69 6c 65 20 2a 2f 0d 0a | 58 0d 0a 58 09 09 6f 66 |ile */..|X..X..of|
|00002140| 66 73 65 74 20 3d 20 30 | 3b 0d 0a 58 09 09 2f 2a |fset = 0|;..X../*|
|00002150| 20 52 6f 75 6e 64 20 73 | 69 7a 65 20 64 6f 77 6e | Round s|ize down|
|00002160| 20 74 6f 20 69 6e 74 65 | 67 72 61 6c 20 6e 75 6d | to inte|gral num|
|00002170| 62 65 72 20 6f 66 20 63 | 6f 64 65 73 20 2a 2f 0d |ber of c|odes */.|
|00002180| 0a 58 09 09 73 69 7a 65 | 20 3d 20 28 73 69 7a 65 |.X..size| = (size|
|00002190| 20 3c 3c 20 33 29 20 2d | 20 28 6e 5f 62 69 74 73 | << 3) -| (n_bits|
|000021a0| 20 2d 20 31 29 3b 0d 0a | 58 09 7d 0d 0a 58 09 72 | - 1);..|X.}..X.r|
|000021b0| 5f 6f 66 66 20 3d 20 6f | 66 66 73 65 74 3b 0d 0a |_off = o|ffset;..|
|000021c0| 58 09 62 69 74 73 20 3d | 20 6e 5f 62 69 74 73 3b |X.bits =| n_bits;|
|000021d0| 0d 0a 58 0d 0a 58 09 2f | 2a 0d 0a 58 09 20 2a 20 |..X..X./|*..X. * |
|000021e0| 47 65 74 20 74 6f 20 74 | 68 65 20 66 69 72 73 74 |Get to t|he first|
|000021f0| 20 62 79 74 65 2e 20 0d | 0a 58 09 20 2a 2f 0d 0a | byte. .|.X. */..|
|00002200| 58 09 62 70 20 2b 3d 20 | 28 72 5f 6f 66 66 20 3e |X.bp += |(r_off >|
|00002210| 3e 20 33 29 3b 0d 0a 58 | 09 72 5f 6f 66 66 20 26 |> 3);..X|.r_off &|
|00002220| 3d 20 37 3b 0d 0a 58 0d | 0a 58 09 2f 2a 20 47 65 |= 7;..X.|.X./* Ge|
|00002230| 74 20 66 69 72 73 74 20 | 70 61 72 74 20 28 6c 6f |t first |part (lo|
|00002240| 77 20 6f 72 64 65 72 20 | 62 69 74 73 29 20 2a 2f |w order |bits) */|
|00002250| 0d 0a 58 09 63 6f 64 65 | 20 3d 20 28 2a 62 70 2b |..X.code| = (*bp+|
|00002260| 2b 20 3e 3e 20 72 5f 6f | 66 66 29 3b 0d 0a 58 09 |+ >> r_o|ff);..X.|
|00002270| 62 69 74 73 20 2d 3d 20 | 38 20 2d 20 72 5f 6f 66 |bits -= |8 - r_of|
|00002280| 66 3b 0d 0a 58 09 72 5f | 6f 66 66 20 3d 20 38 20 |f;..X.r_|off = 8 |
|00002290| 2d 20 72 5f 6f 66 66 3b | 09 2f 2a 20 6e 6f 77 2c |- r_off;|./* now,|
|000022a0| 20 6f 66 66 73 65 74 20 | 69 6e 74 6f 20 63 6f 64 | offset |into cod|
|000022b0| 65 20 77 6f 72 64 20 2a | 2f 0d 0a 58 0d 0a 58 09 |e word *|/..X..X.|
|000022c0| 2f 2a 20 47 65 74 20 61 | 6e 79 20 38 20 62 69 74 |/* Get a|ny 8 bit|
|000022d0| 20 70 61 72 74 73 20 69 | 6e 20 74 68 65 20 6d 69 | parts i|n the mi|
|000022e0| 64 64 6c 65 20 28 3c 3d | 31 20 66 6f 72 20 75 70 |ddle (<=|1 for up|
|000022f0| 20 74 6f 20 31 36 20 62 | 69 74 73 29 2e 20 2a 2f | to 16 b|its). */|
|00002300| 0d 0a 58 09 69 66 20 28 | 62 69 74 73 20 3e 3d 20 |..X.if (|bits >= |
|00002310| 38 29 20 7b 0d 0a 58 09 | 09 63 6f 64 65 20 7c 3d |8) {..X.|.code |=|
|00002320| 20 2a 62 70 2b 2b 20 3c | 3c 20 72 5f 6f 66 66 3b | *bp++ <|< r_off;|
|00002330| 0d 0a 58 09 09 72 5f 6f | 66 66 20 2b 3d 20 38 3b |..X..r_o|ff += 8;|
|00002340| 0d 0a 58 09 09 62 69 74 | 73 20 2d 3d 20 38 3b 0d |..X..bit|s -= 8;.|
|00002350| 0a 58 09 7d 0d 0a 58 09 | 2f 2a 20 68 69 67 68 20 |.X.}..X.|/* high |
|00002360| 6f 72 64 65 72 20 62 69 | 74 73 2e 20 2a 2f 0d 0a |order bi|ts. */..|
|00002370| 58 09 63 6f 64 65 20 7c | 3d 20 28 2a 62 70 20 26 |X.code ||= (*bp &|
|00002380| 20 72 6d 61 73 6b 5b 62 | 69 74 73 5d 29 20 3c 3c | rmask[b|its]) <<|
|00002390| 20 72 5f 6f 66 66 3b 0d | 0a 58 09 6f 66 66 73 65 | r_off;.|.X.offse|
|000023a0| 74 20 2b 3d 20 6e 5f 62 | 69 74 73 3b 0d 0a 58 0d |t += n_b|its;..X.|
|000023b0| 0a 58 09 72 65 74 75 72 | 6e 20 63 6f 64 65 3b 0d |.X.retur|n code;.|
|000023c0| 0a 58 7d 0d 0a 58 0d 0a | 58 2f 2a 0d 0a 58 20 2a |.X}..X..|X/*..X *|
|000023d0| 20 63 6f 6d 70 72 65 73 | 73 20 61 20 66 69 6c 65 | compres|s a file|
|000023e0| 0d 0a 58 20 2a 0d 0a 58 | 20 2a 20 41 6c 67 6f 72 |..X *..X| * Algor|
|000023f0| 69 74 68 6d 3a 20 20 75 | 73 65 20 6f 70 65 6e 20 |ithm: u|se open |
|00002400| 61 64 64 72 65 73 73 69 | 6e 67 20 64 6f 75 62 6c |addressi|ng doubl|
|00002410| 65 20 68 61 73 68 69 6e | 67 20 28 6e 6f 20 63 68 |e hashin|g (no ch|
|00002420| 61 69 6e 69 6e 67 29 20 | 6f 6e 20 74 68 65 0d 0a |aining) |on the..|
|00002430| 58 20 2a 20 70 72 65 66 | 69 78 20 63 6f 64 65 20 |X * pref|ix code |
|00002440| 2f 20 6e 65 78 74 20 63 | 68 61 72 61 63 74 65 72 |/ next c|haracter|
|00002450| 20 63 6f 6d 62 69 6e 61 | 74 69 6f 6e 2e 20 20 57 | combina|tion. W|
|00002460| 65 20 64 6f 20 61 20 76 | 61 72 69 61 6e 74 20 6f |e do a v|ariant o|
|00002470| 66 20 4b 6e 75 74 68 27 | 73 0d 0a 58 20 2a 20 61 |f Knuth'|s..X * a|
|00002480| 6c 67 6f 72 69 74 68 6d | 20 44 20 28 76 6f 6c 2e |lgorithm| D (vol.|
|00002490| 20 33 2c 20 73 65 63 2e | 20 36 2e 34 29 20 61 6c | 3, sec.| 6.4) al|
|000024a0| 6f 6e 67 20 77 69 74 68 | 20 47 2e 20 4b 6e 6f 74 |ong with| G. Knot|
|000024b0| 74 27 73 20 72 65 6c 61 | 74 69 76 65 6c 79 2d 70 |t's rela|tively-p|
|000024c0| 72 69 6d 65 0d 0a 58 20 | 2a 20 73 65 63 6f 6e 64 |rime..X |* second|
|000024d0| 61 72 79 20 70 72 6f 62 | 65 2e 20 20 48 65 72 65 |ary prob|e. Here|
|000024e0| 2c 20 74 68 65 20 6d 6f | 64 75 6c 61 72 20 64 69 |, the mo|dular di|
|000024f0| 76 69 73 69 6f 6e 20 66 | 69 72 73 74 20 70 72 6f |vision f|irst pro|
|00002500| 62 65 20 69 73 20 67 69 | 76 65 73 20 77 61 79 0d |be is gi|ves way.|
|00002510| 0a 58 20 2a 20 74 6f 20 | 61 20 66 61 73 74 65 72 |.X * to |a faster|
|00002520| 20 65 78 63 6c 75 73 69 | 76 65 2d 6f 72 20 6d 61 | exclusi|ve-or ma|
|00002530| 6e 69 70 75 6c 61 74 69 | 6f 6e 2e 20 20 41 6c 73 |nipulati|on. Als|
|00002540| 6f 20 64 6f 20 62 6c 6f | 63 6b 20 63 6f 6d 70 72 |o do blo|ck compr|
|00002550| 65 73 73 69 6f 6e 20 77 | 69 74 68 0d 0a 58 20 2a |ession w|ith..X *|
|00002560| 20 61 6e 20 61 64 61 70 | 74 69 76 65 20 72 65 73 | an adap|tive res|
|00002570| 65 74 2c 20 77 68 65 72 | 65 20 74 68 65 20 63 6f |et, wher|e the co|
|00002580| 64 65 20 74 61 62 6c 65 | 20 69 73 20 63 6c 65 61 |de table| is clea|
|00002590| 72 65 64 20 77 68 65 6e | 20 74 68 65 20 63 6f 6d |red when| the com|
|000025a0| 70 72 65 73 73 69 6f 6e | 0d 0a 58 20 2a 20 72 61 |pression|..X * ra|
|000025b0| 74 69 6f 20 64 65 63 72 | 65 61 73 65 73 2c 20 62 |tio decr|eases, b|
|000025c0| 75 74 20 61 66 74 65 72 | 20 74 68 65 20 74 61 62 |ut after| the tab|
|000025d0| 6c 65 20 66 69 6c 6c 73 | 2e 20 20 54 68 65 20 76 |le fills|. The v|
|000025e0| 61 72 69 61 62 6c 65 2d | 6c 65 6e 67 74 68 20 6f |ariable-|length o|
|000025f0| 75 74 70 75 74 0d 0a 58 | 20 2a 20 63 6f 64 65 73 |utput..X| * codes|
|00002600| 20 61 72 65 20 72 65 2d | 73 69 7a 65 64 20 61 74 | are re-|sized at|
|00002610| 20 74 68 69 73 20 70 6f | 69 6e 74 2c 20 61 6e 64 | this po|int, and|
|00002620| 20 61 20 73 70 65 63 69 | 61 6c 20 43 4c 45 41 52 | a speci|al CLEAR|
|00002630| 20 63 6f 64 65 20 69 73 | 20 67 65 6e 65 72 61 74 | code is| generat|
|00002640| 65 64 0d 0a 58 20 2a 20 | 66 6f 72 20 74 68 65 20 |ed..X * |for the |
|00002650| 64 65 63 6f 6d 70 72 65 | 73 73 6f 72 2e 0d 0a 58 |decompre|ssor...X|
|00002660| 20 2a 2f 0d 0a 58 0d 0a | 58 76 6f 69 64 0d 0a 58 | */..X..|Xvoid..X|
|00002670| 73 71 69 6e 69 74 5f 63 | 6d 28 29 09 09 09 2f 2a |sqinit_c|m().../*|
|00002680| 20 69 6e 69 74 69 61 6c | 69 7a 65 20 66 6f 72 20 | initial|ize for |
|00002690| 63 6f 6d 70 72 65 73 73 | 69 6f 6e 20 2a 2f 0d 0a |compress|ion */..|
|000026a0| 58 7b 0d 0a 58 09 6f 66 | 66 73 65 74 20 3d 20 30 |X{..X.of|fset = 0|
|000026b0| 3b 0d 0a 58 09 62 79 74 | 65 73 5f 6f 75 74 20 3d |;..X.byt|es_out =|
|000026c0| 20 30 3b 0d 0a 58 09 63 | 6c 65 61 72 5f 66 6c 67 | 0;..X.c|lear_flg|
|000026d0| 20 3d 20 30 3b 0d 0a 58 | 09 72 61 74 69 6f 20 3d | = 0;..X|.ratio =|
|000026e0| 20 30 3b 0d 0a 58 09 69 | 6e 5f 63 6f 75 6e 74 20 | 0;..X.i|n_count |
|000026f0| 3d 20 31 3b 0d 0a 58 09 | 63 68 65 63 6b 70 6f 69 |= 1;..X.|checkpoi|
|00002700| 6e 74 20 3d 20 43 48 45 | 43 4b 5f 47 41 50 3b 0d |nt = CHE|CK_GAP;.|
|00002710| 0a 58 09 6d 61 78 63 6f | 64 65 20 3d 20 4d 41 58 |.X.maxco|de = MAX|
|00002720| 43 4f 44 45 28 6e 5f 62 | 69 74 73 20 3d 20 49 4e |CODE(n_b|its = IN|
|00002730| 49 54 5f 42 49 54 53 29 | 3b 0d 0a 58 09 66 72 65 |IT_BITS)|;..X.fre|
|00002740| 65 5f 65 6e 74 20 3d 20 | 46 49 52 53 54 3b 0d 0a |e_ent = |FIRST;..|
|00002750| 58 09 73 65 74 6d 65 6d | 28 68 74 61 62 2c 20 48 |X.setmem|(htab, H|
|00002760| 53 49 5a 45 20 2a 20 73 | 69 7a 65 6f 66 28 6c 6f |SIZE * s|izeof(lo|
|00002770| 6e 67 29 2c 20 30 78 66 | 66 29 3b 0d 0a 58 09 6e |ng), 0xf|f);..X.n|
|00002780| 5f 62 69 74 73 20 3d 20 | 49 4e 49 54 5f 42 49 54 |_bits = |INIT_BIT|
|00002790| 53 3b 09 2f 2a 20 73 65 | 74 20 73 74 61 72 74 69 |S;./* se|t starti|
|000027a0| 6e 67 20 63 6f 64 65 20 | 73 69 7a 65 20 2a 2f 0d |ng code |size */.|
|000027b0| 0a 58 0d 0a 58 09 66 69 | 72 73 74 63 6d 70 20 3d |.X..X.fi|rstcmp =|
|000027c0| 20 31 3b 09 09 2f 2a 20 | 6e 65 78 74 20 62 79 74 | 1;../* |next byt|
|000027d0| 65 20 77 69 6c 6c 20 62 | 65 20 66 69 72 73 74 20 |e will b|e first |
|000027e0| 2a 2f 0d 0a 58 7d 0d 0a | 58 0d 0a 58 76 6f 69 64 |*/..X}..|X..Xvoid|
|000027f0| 0d 0a 58 73 71 70 75 74 | 63 5f 63 6d 28 63 2c 20 |..Xsqput|c_cm(c, |
|00002800| 74 29 09 09 09 2f 2a 20 | 63 6f 6d 70 72 65 73 73 |t).../* |compress|
|00002810| 20 61 20 63 68 61 72 61 | 63 74 65 72 20 2a 2f 0d | a chara|cter */.|
|00002820| 0a 58 09 75 6e 73 69 67 | 6e 65 64 20 63 68 61 72 |.X.unsig|ned char|
|00002830| 20 20 20 63 3b 09 2f 2a | 20 63 68 61 72 61 63 74 | c;./*| charact|
|00002840| 65 72 20 74 6f 20 63 6f | 6d 70 72 65 73 73 20 2a |er to co|mpress *|
|00002850| 2f 0d 0a 58 09 46 49 4c | 45 20 20 20 20 20 20 20 |/..X.FIL|E |
|00002860| 20 20 20 20 2a 74 3b 09 | 2f 2a 20 77 68 65 72 65 | *t;.|/* where|
|00002870| 20 74 6f 20 70 75 74 20 | 69 74 20 2a 2f 0d 0a 58 | to put |it */..X|
|00002880| 7b 0d 0a 58 09 73 74 61 | 74 69 63 20 6c 6f 6e 67 |{..X.sta|tic long|
|00002890| 20 20 20 20 20 66 63 6f | 64 65 3b 0d 0a 58 09 73 | fco|de;..X.s|
|000028a0| 74 61 74 69 63 20 69 6e | 74 20 20 20 20 20 20 68 |tatic in|t h|
|000028b0| 73 68 69 66 74 3b 0d 0a | 58 09 69 6e 74 20 20 20 |shift;..|X.int |
|000028c0| 20 20 20 20 20 20 20 20 | 20 20 69 3b 0d 0a 58 09 | | i;..X.|
|000028d0| 69 6e 74 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |int | |
|000028e0| 64 69 73 70 3b 0d 0a 58 | 0d 0a 58 09 69 66 20 28 |disp;..X|..X.if (|
|000028f0| 66 69 72 73 74 63 6d 70 | 29 20 7b 09 09 2f 2a 20 |firstcmp|) {../* |
|00002900| 73 70 65 63 69 61 6c 20 | 63 61 73 65 20 66 6f 72 |special |case for|
|00002910| 20 66 69 72 73 74 20 62 | 79 74 65 20 2a 2f 0d 0a | first b|yte */..|
|00002920| 58 09 09 65 6e 74 20 3d | 20 63 3b 09 2f 2a 20 72 |X..ent =| c;./* r|
|00002930| 65 6d 65 6d 62 65 72 20 | 66 69 72 73 74 20 62 79 |emember |first by|
|00002940| 74 65 20 2a 2f 0d 0a 58 | 0d 0a 58 09 09 68 73 68 |te */..X|..X..hsh|
|00002950| 69 66 74 20 3d 20 30 3b | 0d 0a 58 09 09 66 6f 72 |ift = 0;|..X..for|
|00002960| 20 28 66 63 6f 64 65 20 | 3d 20 28 6c 6f 6e 67 29 | (fcode |= (long)|
|00002970| 20 48 53 49 5a 45 3b 20 | 66 63 6f 64 65 20 3c 20 | HSIZE; |fcode < |
|00002980| 36 35 35 33 36 4c 3b 20 | 66 63 6f 64 65 20 2a 3d |65536L; |fcode *=|
|00002990| 20 32 4c 29 0d 0a 58 09 | 09 09 68 73 68 69 66 74 | 2L)..X.|..hshift|
|000029a0| 2b 2b 3b 0d 0a 58 09 09 | 68 73 68 69 66 74 20 3d |++;..X..|hshift =|
|000029b0| 20 38 20 2d 20 68 73 68 | 69 66 74 3b 09 2f 2a 20 | 8 - hsh|ift;./* |
|000029c0| 73 65 74 20 68 61 73 68 | 20 63 6f 64 65 20 72 61 |set hash| code ra|
|000029d0| 6e 67 65 20 62 75 6e 64 | 20 2a 2f 0d 0a 58 0d 0a |nge bund| */..X..|
|000029e0| 58 09 09 66 69 72 73 74 | 63 6d 70 20 3d 20 30 3b |X..first|cmp = 0;|
|000029f0| 09 2f 2a 20 6e 6f 20 6c | 6f 6e 67 65 72 20 66 69 |./* no l|onger fi|
|00002a00| 72 73 74 20 2a 2f 0d 0a | 58 09 09 72 65 74 75 72 |rst */..|X..retur|
|00002a10| 6e 3b 0d 0a 58 09 7d 0d | 0a 58 09 69 6e 5f 63 6f |n;..X.}.|.X.in_co|
|00002a20| 75 6e 74 2b 2b 3b 0d 0a | 58 09 66 63 6f 64 65 20 |unt++;..|X.fcode |
|00002a30| 3d 20 28 6c 6f 6e 67 29 | 20 28 28 28 6c 6f 6e 67 |= (long)| (((long|
|00002a40| 29 20 63 20 3c 3c 20 42 | 49 54 53 29 20 2b 20 65 |) c << B|ITS) + e|
|00002a50| 6e 74 29 3b 0d 0a 58 09 | 69 20 3d 20 28 63 20 3c |nt);..X.|i = (c <|
|00002a60| 3c 20 68 73 68 69 66 74 | 29 20 5e 20 65 6e 74 3b |< hshift|) ^ ent;|
|00002a70| 2f 2a 20 78 6f 72 20 68 | 61 73 68 69 6e 67 20 2a |/* xor h|ashing *|
|00002a80| 2f 0d 0a 58 0d 0a 58 09 | 69 66 20 28 68 74 61 62 |/..X..X.|if (htab|
|00002a90| 5b 69 5d 20 3d 3d 20 66 | 63 6f 64 65 29 20 7b 0d |[i] == f|code) {.|
|00002aa0| 0a 58 09 09 65 6e 74 20 | 3d 20 63 6f 64 65 74 61 |.X..ent |= codeta|
|00002ab0| 62 5b 69 5d 3b 0d 0a 58 | 09 09 72 65 74 75 72 6e |b[i];..X|..return|
|00002ac0| 3b 0d 0a 58 09 7d 20 65 | 6c 73 65 20 69 66 20 28 |;..X.} e|lse if (|
|00002ad0| 68 74 61 62 5b 69 5d 20 | 3c 20 30 29 09 2f 2a 20 |htab[i] |< 0)./* |
|00002ae0| 65 6d 70 74 79 20 73 6c | 6f 74 20 2a 2f 0d 0a 58 |empty sl|ot */..X|
|00002af0| 09 09 67 6f 74 6f 20 6e | 6f 6d 61 74 63 68 3b 0d |..goto n|omatch;.|
|00002b00| 0a 58 09 64 69 73 70 20 | 3d 20 48 53 49 5a 45 20 |.X.disp |= HSIZE |
|00002b10| 2d 20 69 3b 09 2f 2a 20 | 73 65 63 6f 6e 64 61 72 |- i;./* |secondar|
|00002b20| 79 20 68 61 73 68 20 28 | 61 66 74 65 72 20 47 2e |y hash (|after G.|
|00002b30| 4b 6e 6f 74 74 29 20 2a | 2f 0d 0a 58 09 69 66 20 |Knott) *|/..X.if |
|00002b40| 28 69 20 3d 3d 20 30 29 | 0d 0a 58 09 09 64 69 73 |(i == 0)|..X..dis|
|00002b50| 70 20 3d 20 31 3b 0d 0a | 58 0d 0a 58 70 72 6f 62 |p = 1;..|X..Xprob|
|00002b60| 65 3a 0d 0a 58 09 69 66 | 20 28 28 69 20 2d 3d 20 |e:..X.if| ((i -= |
|00002b70| 64 69 73 70 29 20 3c 20 | 30 29 0d 0a 58 09 09 69 |disp) < |0)..X..i|
|00002b80| 20 2b 3d 20 48 53 49 5a | 45 3b 0d 0a 58 0d 0a 58 | += HSIZ|E;..X..X|
|00002b90| 09 69 66 20 28 68 74 61 | 62 5b 69 5d 20 3d 3d 20 |.if (hta|b[i] == |
|00002ba0| 66 63 6f 64 65 29 20 7b | 0d 0a 58 09 09 65 6e 74 |fcode) {|..X..ent|
|00002bb0| 20 3d 20 63 6f 64 65 74 | 61 62 5b 69 5d 3b 0d 0a | = codet|ab[i];..|
|00002bc0| 58 09 09 72 65 74 75 72 | 6e 3b 0d 0a 58 09 7d 0d |X..retur|n;..X.}.|
|00002bd0| 0a 58 09 69 66 20 28 68 | 74 61 62 5b 69 5d 20 3e |.X.if (h|tab[i] >|
|00002be0| 20 30 29 0d 0a 58 09 09 | 67 6f 74 6f 20 70 72 6f | 0)..X..|goto pro|
|00002bf0| 62 65 3b 0d 0a 58 0d 0a | 58 6e 6f 6d 61 74 63 68 |be;..X..|Xnomatch|
|00002c00| 3a 0d 0a 58 09 70 75 74 | 63 6f 64 65 28 65 6e 74 |:..X.put|code(ent|
|00002c10| 2c 20 74 29 3b 0d 0a 58 | 09 65 6e 74 20 3d 20 63 |, t);..X|.ent = c|
|00002c20| 3b 0d 0a 58 09 69 66 20 | 28 66 72 65 65 5f 65 6e |;..X.if |(free_en|
|00002c30| 74 20 3c 20 6d 61 78 63 | 6f 64 65 6d 61 78 29 20 |t < maxc|odemax) |
|00002c40| 7b 0d 0a 58 09 09 63 6f | 64 65 74 61 62 5b 69 5d |{..X..co|detab[i]|
|00002c50| 20 3d 20 66 72 65 65 5f | 65 6e 74 2b 2b 3b 09 2f | = free_|ent++;./|
|00002c60| 2a 20 63 6f 64 65 20 2d | 3e 20 68 61 73 68 74 61 |* code -|> hashta|
|00002c70| 62 6c 65 20 2a 2f 0d 0a | 58 09 09 68 74 61 62 5b |ble */..|X..htab[|
|00002c80| 69 5d 20 3d 20 66 63 6f | 64 65 3b 0d 0a 58 09 7d |i] = fco|de;..X.}|
|00002c90| 20 65 6c 73 65 20 69 66 | 20 28 28 6c 6f 6e 67 29 | else if| ((long)|
|00002ca0| 20 69 6e 5f 63 6f 75 6e | 74 20 3e 3d 20 63 68 65 | in_coun|t >= che|
|00002cb0| 63 6b 70 6f 69 6e 74 29 | 0d 0a 58 09 09 63 6c 5f |ckpoint)|..X..cl_|
|00002cc0| 62 6c 6f 63 6b 28 74 29 | 3b 0d 0a 58 7d 0d 0a 58 |block(t)|;..X}..X|
|00002cd0| 0d 0a 58 6c 6f 6e 67 20 | 0d 0a 58 73 71 70 72 65 |..Xlong |..Xsqpre|
|00002ce0| 64 5f 63 6d 28 74 29 09 | 09 09 2f 2a 20 66 69 6e |d_cm(t).|../* fin|
|00002cf0| 69 73 68 20 63 6f 6d 70 | 72 65 73 73 69 6e 67 20 |ish comp|ressing |
|00002d00| 61 20 66 69 6c 65 20 2a | 2f 0d 0a 58 09 46 49 4c |a file *|/..X.FIL|
|00002d10| 45 20 20 20 20 20 20 20 | 20 20 20 20 2a 74 3b 09 |E | *t;.|
|00002d20| 2f 2a 20 77 68 65 72 65 | 20 74 6f 20 70 75 74 20 |/* where| to put |
|00002d30| 69 74 20 2a 2f 0d 0a 58 | 7b 0d 0a 58 09 70 75 74 |it */..X|{..X.put|
|00002d40| 63 6f 64 65 28 65 6e 74 | 2c 20 74 29 3b 09 2f 2a |code(ent|, t);./*|
|00002d50| 20 70 75 74 20 6f 75 74 | 20 74 68 65 20 66 69 6e | put out| the fin|
|00002d60| 61 6c 20 63 6f 64 65 20 | 2a 2f 0d 0a 58 09 70 75 |al code |*/..X.pu|
|00002d70| 74 63 6f 64 65 28 2d 31 | 2c 20 74 29 3b 09 09 2f |tcode(-1|, t);../|
|00002d80| 2a 20 74 65 6c 6c 20 6f | 75 74 70 75 74 20 77 65 |* tell o|utput we|
|00002d90| 20 61 72 65 20 64 6f 6e | 65 20 2a 2f 0d 0a 58 0d | are don|e */..X.|
|00002da0| 0a 58 09 72 65 74 75 72 | 6e 20 62 79 74 65 73 5f |.X.retur|n bytes_|
|00002db0| 6f 75 74 3b 09 2f 2a 20 | 73 61 79 20 68 6f 77 20 |out;./* |say how |
|00002dc0| 62 69 67 20 69 74 20 67 | 6f 74 20 2a 2f 0d 0a 58 |big it g|ot */..X|
|00002dd0| 7d 0d 0a 58 0d 0a 58 2f | 2a 0d 0a 58 20 2a 20 44 |}..X..X/|*..X * D|
|00002de0| 65 63 6f 6d 70 72 65 73 | 73 20 61 20 66 69 6c 65 |ecompres|s a file|
|00002df0| 2e 20 20 54 68 69 73 20 | 72 6f 75 74 69 6e 65 20 |. This |routine |
|00002e00| 61 64 61 70 74 73 20 74 | 6f 20 74 68 65 20 63 6f |adapts t|o the co|
|00002e10| 64 65 73 20 69 6e 20 74 | 68 65 20 66 69 6c 65 0d |des in t|he file.|
|00002e20| 0a 58 20 2a 20 62 75 69 | 6c 64 69 6e 67 20 74 68 |.X * bui|lding th|
|00002e30| 65 20 73 74 72 69 6e 67 | 20 74 61 62 6c 65 20 6f |e string| table o|
|00002e40| 6e 2d 74 68 65 2d 66 6c | 79 3b 20 72 65 71 75 69 |n-the-fl|y; requi|
|00002e50| 72 69 6e 67 20 6e 6f 20 | 74 61 62 6c 65 20 74 6f |ring no |table to|
|00002e60| 20 62 65 20 73 74 6f 72 | 65 64 0d 0a 58 20 2a 20 | be stor|ed..X * |
|00002e70| 69 6e 20 74 68 65 20 63 | 6f 6d 70 72 65 73 73 65 |in the c|ompresse|
|00002e80| 64 20 66 69 6c 65 2e 20 | 20 54 68 65 20 74 61 62 |d file. | The tab|
|00002e90| 6c 65 73 20 75 73 65 64 | 20 68 65 72 65 69 6e 20 |les used| herein |
|00002ea0| 61 72 65 20 73 68 61 72 | 65 64 20 77 69 74 68 20 |are shar|ed with |
|00002eb0| 74 68 6f 73 65 20 6f 66 | 0d 0a 58 20 2a 20 74 68 |those of|..X * th|
|00002ec0| 65 20 63 6f 6d 70 72 65 | 73 73 28 29 20 72 6f 75 |e compre|ss() rou|
|00002ed0| 74 69 6e 65 2e 20 20 53 | 65 65 20 74 68 65 20 64 |tine. S|ee the d|
|00002ee0| 65 66 69 6e 69 74 69 6f | 6e 73 20 61 62 6f 76 65 |efinitio|ns above|
|00002ef0| 2e 0d 0a 58 20 2a 2f 0d | 0a 58 0d 0a 58 76 6f 69 |...X */.|.X..Xvoi|
|00002f00| 64 0d 0a 58 73 71 64 65 | 63 6f 6d 70 28 66 2c 20 |d..Xsqde|comp(f, |
|00002f10| 74 29 09 09 09 2f 2a 20 | 64 65 63 6f 6d 70 72 65 |t).../* |decompre|
|00002f20| 73 73 20 61 20 66 69 6c | 65 20 2a 2f 0d 0a 58 09 |ss a fil|e */..X.|
|00002f30| 46 49 4c 45 20 20 20 20 | 20 20 20 20 20 20 20 2a |FILE | *|
|00002f40| 66 3b 09 2f 2a 20 66 69 | 6c 65 20 74 6f 20 72 65 |f;./* fi|le to re|
|00002f50| 61 64 20 63 6f 64 65 73 | 20 66 72 6f 6d 20 2a 2f |ad codes| from */|
|00002f60| 0d 0a 58 09 46 49 4c 45 | 20 20 20 20 20 20 20 20 |..X.FILE| |
|00002f70| 20 20 20 2a 74 3b 09 2f | 2a 20 66 69 6c 65 20 74 | *t;./|* file t|
|00002f80| 6f 20 77 72 69 74 65 20 | 74 65 78 74 20 74 6f 20 |o write |text to |
|00002f90| 2a 2f 0d 0a 58 7b 0d 0a | 58 09 75 6e 73 69 67 6e |*/..X{..|X.unsign|
|00002fa0| 65 64 20 63 68 61 72 20 | 20 2a 73 74 61 63 6b 70 |ed char | *stackp|
|00002fb0| 3b 0d 0a 58 09 69 6e 74 | 20 20 20 20 20 20 20 20 |;..X.int| |
|00002fc0| 20 20 20 20 20 66 69 6e | 63 68 61 72 3b 0d 0a 58 | fin|char;..X|
|00002fd0| 09 69 6e 74 20 20 20 20 | 20 20 20 20 20 20 20 20 |.int | |
|00002fe0| 20 63 6f 64 65 2c 20 6f | 6c 64 63 6f 64 65 2c 20 | code, o|ldcode, |
|00002ff0| 69 6e 63 6f 64 65 3b 0d | 0a 58 0d 0a 58 09 6e 5f |incode;.|.X..X.n_|
|00003000| 62 69 74 73 20 3d 20 49 | 4e 49 54 5f 42 49 54 53 |bits = I|NIT_BITS|
|00003010| 3b 09 2f 2a 20 73 65 74 | 20 73 74 61 72 74 69 6e |;./* set| startin|
|00003020| 67 20 63 6f 64 65 20 73 | 69 7a 65 20 2a 2f 0d 0a |g code s|ize */..|
|00003030| 58 09 63 6c 65 61 72 5f | 66 6c 67 20 3d 20 30 3b |X.clear_|flg = 0;|
|00003040| 0d 0a 58 0d 0a 58 09 2f | 2a 0d 0a 58 09 20 2a 20 |..X..X./|*..X. * |
|00003050| 41 73 20 61 62 6f 76 65 | 2c 20 69 6e 69 74 69 61 |As above|, initia|
|00003060| 6c 69 7a 65 20 74 68 65 | 20 66 69 72 73 74 20 32 |lize the| first 2|
|00003070| 35 36 20 65 6e 74 72 69 | 65 73 20 69 6e 20 74 68 |56 entri|es in th|
|00003080| 65 20 74 61 62 6c 65 2e | 20 0d 0a 58 09 20 2a 2f |e table.| ..X. */|
|00003090| 0d 0a 58 09 6d 61 78 63 | 6f 64 65 20 3d 20 4d 41 |..X.maxc|ode = MA|
|000030a0| 58 43 4f 44 45 28 6e 5f | 62 69 74 73 20 3d 20 49 |XCODE(n_|bits = I|
|000030b0| 4e 49 54 5f 42 49 54 53 | 29 3b 0d 0a 58 09 66 6f |NIT_BITS|);..X.fo|
|000030c0| 72 20 28 63 6f 64 65 20 | 3d 20 32 35 35 3b 20 63 |r (code |= 255; c|
|000030d0| 6f 64 65 20 3e 3d 20 30 | 3b 20 63 6f 64 65 2d 2d |ode >= 0|; code--|
|000030e0| 29 20 7b 0d 0a 58 09 09 | 70 72 65 66 69 78 5b 63 |) {..X..|prefix[c|
|000030f0| 6f 64 65 5d 20 3d 20 30 | 3b 0d 0a 58 09 09 73 75 |ode] = 0|;..X..su|
|00003100| 66 66 69 78 5b 63 6f 64 | 65 5d 20 3d 20 28 75 6e |ffix[cod|e] = (un|
|00003110| 73 69 67 6e 65 64 20 63 | 68 61 72 29 20 63 6f 64 |signed c|har) cod|
|00003120| 65 3b 0d 0a 58 09 7d 0d | 0a 58 09 66 72 65 65 5f |e;..X.}.|.X.free_|
|00003130| 65 6e 74 20 3d 20 46 49 | 52 53 54 3b 0d 0a 58 0d |ent = FI|RST;..X.|
|00003140| 0a 58 09 66 69 6e 63 68 | 61 72 20 3d 20 6f 6c 64 |.X.finch|ar = old|
|00003150| 63 6f 64 65 20 3d 20 67 | 65 74 63 6f 64 65 28 66 |code = g|etcode(f|
|00003160| 29 3b 0d 0a 58 09 69 66 | 20 28 6f 6c 64 63 6f 64 |);..X.if| (oldcod|
|00003170| 65 20 3d 3d 20 2d 31 29 | 09 2f 2a 20 45 4f 46 20 |e == -1)|./* EOF |
|00003180| 61 6c 72 65 61 64 79 3f | 20 2a 2f 0d 0a 58 09 09 |already?| */..X..|
|00003190| 72 65 74 75 72 6e 3b 09 | 09 2f 2a 20 47 65 74 20 |return;.|./* Get |
|000031a0| 6f 75 74 20 6f 66 20 68 | 65 72 65 20 2a 2f 0d 0a |out of h|ere */..|
|000031b0| 58 09 70 75 74 63 5f 75 | 6e 70 28 28 63 68 61 72 |X.putc_u|np((char|
|000031c0| 29 20 66 69 6e 63 68 61 | 72 2c 20 74 29 3b 09 2f |) fincha|r, t);./|
|000031d0| 2a 20 66 69 72 73 74 20 | 63 6f 64 65 20 6d 75 73 |* first |code mus|
|000031e0| 74 20 62 65 20 38 20 62 | 69 74 73 3d 63 68 61 72 |t be 8 b|its=char|
|000031f0| 20 2a 2f 0d 0a 58 09 73 | 74 61 63 6b 70 20 3d 20 | */..X.s|tackp = |
|00003200| 73 74 61 63 6b 3b 0d 0a | 58 0d 0a 58 09 77 68 69 |stack;..|X..X.whi|
|00003210| 6c 65 20 28 28 63 6f 64 | 65 20 3d 20 67 65 74 63 |le ((cod|e = getc|
|00003220| 6f 64 65 28 66 29 29 20 | 3e 20 2d 31 29 20 7b 0d |ode(f)) |> -1) {.|
|00003230| 0a 58 09 09 69 66 20 28 | 63 6f 64 65 20 3d 3d 20 |.X..if (|code == |
|00003240| 43 4c 45 41 52 29 20 7b | 0d 0a 58 09 09 09 66 6f |CLEAR) {|..X...fo|
|00003250| 72 20 28 63 6f 64 65 20 | 3d 20 32 35 35 3b 20 63 |r (code |= 255; c|
|00003260| 6f 64 65 20 3e 3d 20 30 | 3b 20 63 6f 64 65 2d 2d |ode >= 0|; code--|
|00003270| 29 0d 0a 58 09 09 09 09 | 70 72 65 66 69 78 5b 63 |)..X....|prefix[c|
|00003280| 6f 64 65 5d 20 3d 20 30 | 3b 0d 0a 58 09 09 09 63 |ode] = 0|;..X...c|
|00003290| 6c 65 61 72 5f 66 6c 67 | 20 3d 20 31 3b 0d 0a 58 |lear_flg| = 1;..X|
|000032a0| 09 09 09 66 72 65 65 5f | 65 6e 74 20 3d 20 46 49 |...free_|ent = FI|
|000032b0| 52 53 54 20 2d 20 31 3b | 0d 0a 58 09 09 09 69 66 |RST - 1;|..X...if|
|000032c0| 20 28 28 63 6f 64 65 20 | 3d 20 67 65 74 63 6f 64 | ((code |= getcod|
|000032d0| 65 28 66 29 29 20 3d 3d | 20 2d 31 29 09 2f 2a 20 |e(f)) ==| -1)./* |
|000032e0| 4f 2c 20 75 6e 74 69 6d | 65 6c 79 20 64 65 61 74 |O, untim|ely deat|
|000032f0| 68 21 20 2a 2f 0d 0a 58 | 09 09 09 09 62 72 65 61 |h! */..X|....brea|
|00003300| 6b 3b 0d 0a 58 09 09 7d | 0d 0a 58 09 09 69 6e 63 |k;..X..}|..X..inc|
|00003310| 6f 64 65 20 3d 20 63 6f | 64 65 3b 0d 0a 58 09 09 |ode = co|de;..X..|
|00003320| 2f 2a 0d 0a 58 09 09 20 | 2a 20 53 70 65 63 69 61 |/*..X.. |* Specia|
|00003330| 6c 20 63 61 73 65 20 66 | 6f 72 20 4b 77 4b 77 4b |l case f|or KwKwK|
|00003340| 20 73 74 72 69 6e 67 2e | 20 0d 0a 58 09 09 20 2a | string.| ..X.. *|
|00003350| 2f 0d 0a 58 09 09 69 66 | 20 28 63 6f 64 65 20 3e |/..X..if| (code >|
|00003360| 3d 20 66 72 65 65 5f 65 | 6e 74 29 20 7b 0d 0a 58 |= free_e|nt) {..X|
|00003370| 09 09 09 69 66 20 28 63 | 6f 64 65 20 3e 20 66 72 |...if (c|ode > fr|
|00003380| 65 65 5f 65 6e 74 29 20 | 7b 0d 0a 58 09 09 09 09 |ee_ent) |{..X....|
|00003390| 69 66 20 28 77 61 72 6e | 29 20 7b 0d 0a 58 09 09 |if (warn|) {..X..|
|000033a0| 09 09 09 70 72 69 6e 74 | 66 28 22 43 6f 72 72 75 |...print|f("Corru|
|000033b0| 70 74 65 64 20 63 6f 6d | 70 72 65 73 73 65 64 20 |pted com|pressed |
|000033c0| 66 69 6c 65 2e 5c 6e 22 | 29 3b 0d 0a 58 09 09 09 |file.\n"|);..X...|
|000033d0| 09 09 70 72 69 6e 74 66 | 28 22 49 6e 76 61 6c 69 |..printf|("Invali|
|000033e0| 64 20 63 6f 64 65 20 25 | 64 20 77 68 65 6e 20 6d |d code %|d when m|
|000033f0| 61 78 20 69 73 20 25 64 | 2e 5c 6e 22 2c 0d 0a 58 |ax is %d|.\n",..X|
|00003400| 09 09 09 09 09 09 63 6f | 64 65 2c 20 66 72 65 65 |......co|de, free|
|00003410| 5f 65 6e 74 29 3b 0d 0a | 58 09 09 09 09 7d 0d 0a |_ent);..|X....}..|
|00003420| 58 09 09 09 09 6e 65 72 | 72 73 2b 2b 3b 0d 0a 58 |X....ner|rs++;..X|
|00003430| 09 09 09 09 72 65 74 75 | 72 6e 3b 0d 0a 58 09 09 |....retu|rn;..X..|
|00003440| 09 7d 0d 0a 58 09 09 09 | 2a 73 74 61 63 6b 70 2b |.}..X...|*stackp+|
|00003450| 2b 20 3d 20 66 69 6e 63 | 68 61 72 3b 0d 0a 58 09 |+ = finc|har;..X.|
|00003460| 09 09 63 6f 64 65 20 3d | 20 6f 6c 64 63 6f 64 65 |..code =| oldcode|
|00003470| 3b 0d 0a 58 09 09 7d 0d | 0a 58 09 09 2f 2a 0d 0a |;..X..}.|.X../*..|
|00003480| 58 09 09 20 2a 20 47 65 | 6e 65 72 61 74 65 20 6f |X.. * Ge|nerate o|
|00003490| 75 74 70 75 74 20 63 68 | 61 72 61 63 74 65 72 73 |utput ch|aracters|
|000034a0| 20 69 6e 20 72 65 76 65 | 72 73 65 20 6f 72 64 65 | in reve|rse orde|
|000034b0| 72 20 0d 0a 58 09 09 20 | 2a 2f 0d 0a 58 09 09 77 |r ..X.. |*/..X..w|
|000034c0| 68 69 6c 65 20 28 63 6f | 64 65 20 3e 3d 20 32 35 |hile (co|de >= 25|
|000034d0| 36 29 20 7b 0d 0a 58 09 | 09 09 2a 73 74 61 63 6b |6) {..X.|..*stack|
|000034e0| 70 2b 2b 20 3d 20 73 75 | 66 66 69 78 5b 63 6f 64 |p++ = su|ffix[cod|
|000034f0| 65 5d 3b 0d 0a 58 09 09 | 09 63 6f 64 65 20 3d 20 |e];..X..|.code = |
|00003500| 70 72 65 66 69 78 5b 63 | 6f 64 65 5d 3b 0d 0a 58 |prefix[c|ode];..X|
|00003510| 09 09 7d 0d 0a 58 09 09 | 2a 73 74 61 63 6b 70 2b |..}..X..|*stackp+|
|00003520| 2b 20 3d 20 66 69 6e 63 | 68 61 72 20 3d 20 73 75 |+ = finc|har = su|
|00003530| 66 66 69 78 5b 63 6f 64 | 65 5d 3b 0d 0a 58 0d 0a |ffix[cod|e];..X..|
|00003540| 58 09 09 2f 2a 0d 0a 58 | 09 09 20 2a 20 41 6e 64 |X../*..X|.. * And|
|00003550| 20 70 75 74 20 74 68 65 | 6d 20 6f 75 74 20 69 6e | put the|m out in|
|00003560| 20 66 6f 72 77 61 72 64 | 20 6f 72 64 65 72 20 0d | forward| order .|
|00003570| 0a 58 09 09 20 2a 2f 0d | 0a 58 09 09 64 6f 0d 0a |.X.. */.|.X..do..|
|00003580| 58 09 09 09 70 75 74 63 | 5f 75 6e 70 28 2a 2d 2d |X...putc|_unp(*--|
|00003590| 73 74 61 63 6b 70 2c 20 | 74 29 3b 0d 0a 58 09 09 |stackp, |t);..X..|
|000035a0| 77 68 69 6c 65 20 28 73 | 74 61 63 6b 70 20 3e 20 |while (s|tackp > |
|000035b0| 73 74 61 63 6b 29 3b 0d | 0a 58 0d 0a 58 09 09 2f |stack);.|.X..X../|
|000035c0| 2a 0d 0a 58 09 09 20 2a | 20 47 65 6e 65 72 61 74 |*..X.. *| Generat|
|000035d0| 65 20 74 68 65 20 6e 65 | 77 20 65 6e 74 72 79 2e |e the ne|w entry.|
|000035e0| 20 0d 0a 58 09 09 20 2a | 2f 0d 0a 58 09 09 69 66 | ..X.. *|/..X..if|
|000035f0| 20 28 28 63 6f 64 65 20 | 3d 20 66 72 65 65 5f 65 | ((code |= free_e|
|00003600| 6e 74 29 20 3c 20 6d 61 | 78 63 6f 64 65 6d 61 78 |nt) < ma|xcodemax|
|00003610| 29 20 7b 0d 0a 58 09 09 | 09 70 72 65 66 69 78 5b |) {..X..|.prefix[|
|00003620| 63 6f 64 65 5d 20 3d 20 | 28 75 6e 73 69 67 6e 65 |code] = |(unsigne|
|00003630| 64 20 73 68 6f 72 74 29 | 20 6f 6c 64 63 6f 64 65 |d short)| oldcode|
|00003640| 3b 0d 0a 58 09 09 09 73 | 75 66 66 69 78 5b 63 6f |;..X...s|uffix[co|
|00003650| 64 65 5d 20 3d 20 66 69 | 6e 63 68 61 72 3b 0d 0a |de] = fi|nchar;..|
|00003660| 58 09 09 09 66 72 65 65 | 5f 65 6e 74 20 3d 20 63 |X...free|_ent = c|
|00003670| 6f 64 65 20 2b 20 31 3b | 0d 0a 58 09 09 7d 0d 0a |ode + 1;|..X..}..|
|00003680| 58 09 09 2f 2a 0d 0a 58 | 09 09 20 2a 20 52 65 6d |X../*..X|.. * Rem|
|00003690| 65 6d 62 65 72 20 70 72 | 65 76 69 6f 75 73 20 63 |ember pr|evious c|
|000036a0| 6f 64 65 2e 20 0d 0a 58 | 09 09 20 2a 2f 0d 0a 58 |ode. ..X|.. */..X|
|000036b0| 09 09 6f 6c 64 63 6f 64 | 65 20 3d 20 69 6e 63 6f |..oldcod|e = inco|
|000036c0| 64 65 3b 0d 0a 58 09 7d | 0d 0a 58 7d 0d 0a 5f 5f |de;..X.}|..X}..__|
|000036d0| 5f 5f 5f 5f 5f 5f 54 68 | 69 73 5f 49 73 5f 54 68 |______Th|is_Is_Th|
|000036e0| 65 5f 45 4e 44 5f 5f 5f | 5f 5f 5f 5f 5f 0d 0a 69 |e_END___|_____..i|
|000036f0| 66 20 74 65 73 74 20 60 | 77 63 20 2d 63 20 3c 20 |f test `|wc -c < |
|00003700| 61 72 63 73 71 73 2e 63 | 60 20 2d 6e 65 20 20 20 |arcsqs.c|` -ne |
|00003710| 20 31 31 35 31 34 3b 20 | 74 68 65 6e 0d 0a 09 65 | 11514; |then...e|
|00003720| 63 68 6f 20 27 73 68 61 | 72 3a 20 61 72 63 73 71 |cho 'sha|r: arcsq|
|00003730| 73 2e 63 20 77 61 73 20 | 64 61 6d 61 67 65 64 20 |s.c was |damaged |
|00003740| 64 75 72 69 6e 67 20 74 | 72 61 6e 73 69 74 20 28 |during t|ransit (|
|00003750| 73 68 6f 75 6c 64 20 68 | 61 76 65 20 62 65 65 6e |should h|ave been|
|00003760| 20 20 20 20 31 31 35 31 | 34 20 62 79 74 65 73 29 | 1151|4 bytes)|
|00003770| 27 0d 0a 66 69 0d 0a 66 | 69 09 09 3b 20 3a 20 65 |'..fi..f|i..; : e|
|00003780| 6e 64 20 6f 66 20 6f 76 | 65 72 77 72 69 74 69 6e |nd of ov|erwritin|
|00003790| 67 20 63 68 65 63 6b 0d | 0a 65 63 68 6f 20 27 78 |g check.|.echo 'x|
|000037a0| 20 2d 20 61 72 63 73 76 | 63 2e 63 27 0d 0a 69 66 | - arcsv|c.c'..if|
|000037b0| 20 74 65 73 74 20 2d 66 | 20 61 72 63 73 76 63 2e | test -f| arcsvc.|
|000037c0| 63 3b 20 74 68 65 6e 20 | 65 63 68 6f 20 27 73 68 |c; then |echo 'sh|
|000037d0| 61 72 3a 20 6e 6f 74 20 | 6f 76 65 72 77 72 69 74 |ar: not |overwrit|
|000037e0| 69 6e 67 20 61 72 63 73 | 76 63 2e 63 27 3b 20 65 |ing arcs|vc.c'; e|
|000037f0| 6c 73 65 0d 0a 73 65 64 | 20 27 73 2f 5e 58 2f 2f |lse..sed| 's/^X//|
|00003800| 27 20 3c 3c 20 27 5f 5f | 5f 5f 5f 5f 5f 5f 54 68 |' << '__|______Th|
|00003810| 69 73 5f 49 73 5f 54 68 | 65 5f 45 4e 44 5f 5f 5f |is_Is_Th|e_END___|
|00003820| 5f 5f 5f 5f 5f 27 20 3e | 20 61 72 63 73 76 63 2e |_____' >| arcsvc.|
|00003830| 63 0d 0a 58 2f 2a 0d 0a | 58 20 2a 20 24 48 65 61 |c..X/*..|X * $Hea|
|00003840| 64 65 72 3a 20 61 72 63 | 73 76 63 2e 63 2c 76 20 |der: arc|svc.c,v |
|00003850| 31 2e 38 20 38 38 2f 30 | 36 2f 31 33 20 30 30 3a |1.8 88/0|6/13 00:|
|00003860| 34 32 3a 35 39 20 68 79 | 63 20 4c 6f 63 6b 65 64 |42:59 hy|c Locked|
|00003870| 20 24 0d 0a 58 20 2a 2f | 0d 0a 58 0d 0a 58 2f 2a | $..X */|..X..X/*|
|00003880| 20 20 41 52 43 20 2d 20 | 41 72 63 68 69 76 65 20 | ARC - |Archive |
|00003890| 75 74 69 6c 69 74 79 20 | 2d 20 41 52 43 53 56 43 |utility |- ARCSVC|
|000038a0| 0d 0a 58 0d 0a 58 20 20 | 20 20 56 65 72 73 69 6f |..X..X | Versio|
|000038b0| 6e 20 32 2e 32 33 2c 20 | 63 72 65 61 74 65 64 20 |n 2.23, |created |
|000038c0| 6f 6e 20 30 34 2f 32 32 | 2f 38 37 20 61 74 20 31 |on 04/22|/87 at 1|
|000038d0| 33 3a 31 30 3a 31 30 0d | 0a 58 0d 0a 58 28 43 29 |3:10:10.|.X..X(C)|
|000038e0| 20 43 4f 50 59 52 49 47 | 48 54 20 31 39 38 35 2d | COPYRIG|HT 1985-|
|000038f0| 38 37 20 62 79 20 53 79 | 73 74 65 6d 20 45 6e 68 |87 by Sy|stem Enh|
|00003900| 61 6e 63 65 6d 65 6e 74 | 20 41 73 73 6f 63 69 61 |ancement| Associa|
|00003910| 74 65 73 3b 20 41 4c 4c | 20 52 49 47 48 54 53 20 |tes; ALL| RIGHTS |
|00003920| 52 45 53 45 52 56 45 44 | 0d 0a 58 0d 0a 58 20 20 |RESERVED|..X..X |
|00003930| 20 20 42 79 3a 09 20 54 | 68 6f 6d 20 48 65 6e 64 | By:. T|hom Hend|
|00003940| 65 72 73 6f 6e 0d 0a 58 | 0d 0a 58 20 20 20 20 44 |erson..X|..X D|
|00003950| 65 73 63 72 69 70 74 69 | 6f 6e 3a 0d 0a 58 09 20 |escripti|on:..X. |
|00003960| 54 68 69 73 20 66 69 6c | 65 20 63 6f 6e 74 61 69 |This fil|e contai|
|00003970| 6e 73 20 73 65 72 76 69 | 63 65 20 72 6f 75 74 69 |ns servi|ce routi|
|00003980| 6e 65 73 20 6e 65 65 64 | 65 64 20 74 6f 20 6d 61 |nes need|ed to ma|
|00003990| 69 6e 74 61 69 6e 20 61 | 6e 20 61 72 63 68 69 76 |intain a|n archiv|
|000039a0| 65 2e 0d 0a 58 0d 0a 58 | 20 20 20 20 4c 61 6e 67 |e...X..X| Lang|
|000039b0| 75 61 67 65 3a 0d 0a 58 | 09 20 43 6f 6d 70 75 74 |uage:..X|. Comput|
|000039c0| 65 72 20 49 6e 6e 6f 76 | 61 74 69 6f 6e 73 20 4f |er Innov|ations O|
|000039d0| 70 74 69 6d 69 7a 69 6e | 67 20 43 38 36 0d 0a 58 |ptimizin|g C86..X|
|000039e0| 2a 2f 0d 0a 58 23 69 6e | 63 6c 75 64 65 20 3c 73 |*/..X#in|clude <s|
|000039f0| 74 64 69 6f 2e 68 3e 0d | 0a 58 23 69 6e 63 6c 75 |tdio.h>.|.X#inclu|
|00003a00| 64 65 20 22 61 72 63 2e | 68 22 0d 0a 58 23 69 66 |de "arc.|h"..X#if|
|00003a10| 09 4d 54 53 0d 0a 58 23 | 69 6e 63 6c 75 64 65 20 |.MTS..X#|include |
|00003a20| 3c 6d 74 73 2e 68 3e 0d | 0a 58 23 65 6e 64 69 66 |<mts.h>.|.X#endif|
|00003a30| 0d 0a 58 0d 0a 58 76 6f | 69 64 09 61 62 6f 72 74 |..X..Xvo|id.abort|
|00003a40| 28 29 2c 20 73 65 74 73 | 74 61 6d 70 28 29 3b 0d |(), sets|tamp();.|
|00003a50| 0a 58 69 6e 74 09 75 6e | 6c 69 6e 6b 28 29 3b 0d |.Xint.un|link();.|
|00003a60| 0a 58 0d 0a 58 76 6f 69 | 64 0d 0a 58 6f 70 65 6e |.X..Xvoi|d..Xopen|
|00003a70| 61 72 63 28 63 68 67 29 | 09 09 09 2f 2a 20 6f 70 |arc(chg)|.../* op|
|00003a80| 65 6e 20 61 72 63 68 69 | 76 65 20 2a 2f 0d 0a 58 |en archi|ve */..X|
|00003a90| 09 69 6e 74 20 20 20 20 | 20 20 20 20 20 20 20 20 |.int | |
|00003aa0| 20 63 68 67 3b 09 2f 2a | 20 74 72 75 65 20 74 6f | chg;./*| true to|
|00003ab0| 20 6f 70 65 6e 20 66 6f | 72 20 63 68 61 6e 67 65 | open fo|r change|
|00003ac0| 73 20 2a 2f 0d 0a 58 7b | 0d 0a 58 09 46 49 4c 45 |s */..X{|..X.FILE|
|00003ad0| 20 20 20 20 20 20 20 20 | 20 20 20 2a 66 6f 70 65 | | *fope|
|00003ae0| 6e 28 29 3b 2f 2a 20 66 | 69 6c 65 20 6f 70 65 6e |n();/* f|ile open|
|00003af0| 65 72 20 2a 2f 0d 0a 58 | 0d 0a 58 09 69 66 20 28 |er */..X|..X.if (|
|00003b00| 21 28 61 72 63 20 3d 20 | 66 6f 70 65 6e 28 61 72 |!(arc = |fopen(ar|
|00003b10| 63 6e 61 6d 65 2c 20 22 | 72 62 22 29 29 29 20 7b |cname, "|rb"))) {|
|00003b20| 0d 0a 58 09 09 69 66 20 | 28 63 68 67 29 20 7b 0d |..X..if |(chg) {.|
|00003b30| 0a 58 09 09 09 69 66 20 | 28 6e 6f 74 65 29 0d 0a |.X...if |(note)..|
|00003b40| 58 09 09 09 09 70 72 69 | 6e 74 66 28 22 43 72 65 |X....pri|ntf("Cre|
|00003b50| 61 74 69 6e 67 20 6e 65 | 77 20 61 72 63 68 69 76 |ating ne|w archiv|
|00003b60| 65 3a 20 25 73 5c 6e 22 | 2c 20 61 72 63 6e 61 6d |e: %s\n"|, arcnam|
|00003b70| 65 29 3b 0d 0a 58 09 09 | 7d 0d 0a 58 09 09 65 6c |e);..X..|}..X..el|
|00003b80| 73 65 0d 0a 58 09 09 09 | 61 62 6f 72 74 28 22 41 |se..X...|abort("A|
|00003b90| 72 63 68 69 76 65 20 6e | 6f 74 20 66 6f 75 6e 64 |rchive n|ot found|
|00003ba0| 3a 20 25 73 22 2c 20 61 | 72 63 6e 61 6d 65 29 3b |: %s", a|rcname);|
|00003bb0| 0d 0a 58 09 7d 0d 0a 58 | 23 69 66 09 4d 54 53 09 |..X.}..X|#if.MTS.|
|00003bc0| 2f 2a 20 61 6c 6c 6f 77 | 20 72 65 61 64 69 6e 67 |/* allow| reading|
|00003bd0| 20 61 72 63 68 69 76 65 | 73 20 6f 66 20 6d 61 78 | archive|s of max|
|00003be0| 20 4d 54 53 20 72 65 63 | 6f 72 64 20 6c 65 6e 67 | MTS rec|ord leng|
|00003bf0| 74 68 20 2a 2f 0d 0a 58 | 09 65 6c 73 65 20 7b 0d |th */..X|.else {.|
|00003c00| 0a 58 09 09 63 68 61 72 | 20 2a 62 75 66 66 65 72 |.X..char| *buffer|
|00003c10| 2c 20 2a 6d 61 6c 6c 6f | 63 28 29 3b 0d 0a 58 09 |, *mallo|c();..X.|
|00003c20| 09 69 6e 74 20 69 6e 6c | 65 6e 3b 0d 0a 58 09 09 |.int inl|en;..X..|
|00003c30| 73 74 72 75 63 74 20 47 | 44 44 53 45 43 54 20 2a |struct G|DDSECT *|
|00003c40| 72 65 67 69 6f 6e 3b 0d | 0a 58 0d 0a 58 09 09 72 |region;.|.X..X..r|
|00003c50| 65 67 69 6f 6e 3d 67 64 | 69 6e 66 6f 28 61 72 63 |egion=gd|info(arc|
|00003c60| 2d 3e 5f 66 64 29 3b 0d | 0a 58 09 09 69 6e 6c 65 |->_fd);.|.X..inle|
|00003c70| 6e 3d 72 65 67 69 6f 6e | 2d 3e 47 44 49 4e 4c 45 |n=region|->GDINLE|
|00003c80| 4e 3b 0d 0a 58 09 09 62 | 75 66 66 65 72 3d 6d 61 |N;..X..b|uffer=ma|
|00003c90| 6c 6c 6f 63 28 69 6e 6c | 65 6e 29 3b 0d 0a 58 09 |lloc(inl|en);..X.|
|00003ca0| 09 73 65 74 62 75 66 28 | 61 72 63 2c 20 62 75 66 |.setbuf(|arc, buf|
|00003cb0| 66 65 72 29 3b 0d 0a 58 | 09 09 61 72 63 2d 3e 5f |fer);..X|..arc->_|
|00003cc0| 62 75 66 73 69 7a 3d 69 | 6e 6c 65 6e 3b 0d 0a 58 |bufsiz=i|nlen;..X|
|00003cd0| 09 7d 0d 0a 58 23 65 6e | 64 69 66 0d 0a 58 09 69 |.}..X#en|dif..X.i|
|00003ce0| 66 20 28 63 68 67 29 20 | 7b 09 09 2f 2a 20 69 66 |f (chg) |{../* if|
|00003cf0| 20 6f 70 65 6e 69 6e 67 | 20 66 6f 72 20 63 68 61 | opening| for cha|
|00003d00| 6e 67 65 73 20 2a 2f 0d | 0a 58 09 09 69 66 20 28 |nges */.|.X..if (|
|00003d10| 21 28 6e 65 77 20 3d 20 | 66 6f 70 65 6e 28 6e 65 |!(new = |fopen(ne|
|00003d20| 77 6e 61 6d 65 2c 20 22 | 77 62 22 29 29 29 0d 0a |wname, "|wb")))..|
|00003d30| 58 09 09 09 61 62 6f 72 | 74 28 22 43 61 6e 6e 6f |X...abor|t("Canno|
|00003d40| 74 20 63 72 65 61 74 65 | 20 61 72 63 68 69 76 65 |t create| archive|
|00003d50| 20 63 6f 70 79 3a 20 25 | 73 22 2c 20 6e 65 77 6e | copy: %|s", newn|
|00003d60| 61 6d 65 29 3b 0d 0a 58 | 0d 0a 58 09 63 68 61 6e |ame);..X|..X.chan|
|00003d70| 67 69 6e 67 20 3d 20 63 | 68 67 3b 09 09 2f 2a 20 |ging = c|hg;../* |
|00003d80| 6e 6f 74 65 20 69 66 20 | 6f 70 65 6e 20 66 6f 72 |note if |open for|
|00003d90| 20 63 68 61 6e 67 65 73 | 20 2a 2f 0d 0a 58 09 7d | changes| */..X.}|
|00003da0| 0d 0a 58 7d 0d 0a 58 0d | 0a 58 76 6f 69 64 0d 0a |..X}..X.|.Xvoid..|
|00003db0| 58 63 6c 6f 73 65 61 72 | 63 28 63 68 67 29 09 09 |Xclosear|c(chg)..|
|00003dc0| 09 2f 2a 20 63 6c 6f 73 | 65 20 61 6e 20 61 72 63 |./* clos|e an arc|
|00003dd0| 68 69 76 65 20 2a 2f 0d | 0a 58 09 69 6e 74 20 20 |hive */.|.X.int |
|00003de0| 20 20 20 20 20 20 20 20 | 20 20 20 63 68 67 3b 09 | | chg;.|
|00003df0| 2f 2a 20 74 72 75 65 20 | 69 66 20 61 72 63 68 69 |/* true |if archi|
|00003e00| 76 65 20 77 61 73 20 63 | 68 61 6e 67 65 64 20 2a |ve was c|hanged *|
|00003e10| 2f 0d 0a 58 7b 0d 0a 58 | 09 69 66 20 28 61 72 63 |/..X{..X|.if (arc|
|00003e20| 29 20 7b 09 09 2f 2a 20 | 69 66 20 77 65 20 68 61 |) {../* |if we ha|
|00003e30| 64 20 61 6e 20 69 6e 69 | 74 69 61 6c 20 61 72 63 |d an ini|tial arc|
|00003e40| 68 69 76 65 20 2a 2f 0d | 0a 58 09 09 66 63 6c 6f |hive */.|.X..fclo|
|00003e50| 73 65 28 61 72 63 29 3b | 0d 0a 58 09 09 69 66 20 |se(arc);|..X..if |
|00003e60| 28 6b 6c 75 64 67 65 29 | 09 2f 2a 20 6b 6c 75 64 |(kludge)|./* klud|
|00003e70| 67 65 20 74 6f 20 75 70 | 64 61 74 65 20 74 69 6d |ge to up|date tim|
|00003e80| 65 73 74 61 6d 70 20 2a | 2f 0d 0a 58 23 69 66 09 |estamp *|/..X#if.|
|00003e90| 21 4d 54 53 0d 0a 58 09 | 09 09 73 65 74 73 74 61 |!MTS..X.|..setsta|
|00003ea0| 6d 70 28 61 72 63 6e 61 | 6d 65 2c 20 6f 6c 64 64 |mp(arcna|me, oldd|
|00003eb0| 61 74 65 2c 20 6f 6c 64 | 74 69 6d 65 29 3b 0d 0a |ate, old|time);..|
|00003ec0| 58 23 65 6e 64 69 66 0d | 0a 58 09 7d 0d 0a 58 09 |X#endif.|.X.}..X.|
|00003ed0| 69 66 20 28 63 68 67 29 | 20 7b 09 09 2f 2a 20 69 |if (chg)| {../* i|
|00003ee0| 66 20 74 68 69 6e 67 73 | 20 68 61 76 65 20 63 68 |f things| have ch|
|00003ef0| 61 6e 67 65 64 20 2a 2f | 0d 0a 58 09 09 66 63 6c |anged */|..X..fcl|
|00003f00| 6f 73 65 28 6e 65 77 29 | 3b 09 2f 2a 20 63 6c 6f |ose(new)|;./* clo|
|00003f10| 73 65 20 74 68 65 20 6e | 65 77 20 63 6f 70 79 20 |se the n|ew copy |
|00003f20| 2a 2f 0d 0a 58 09 09 69 | 66 20 28 61 72 63 29 20 |*/..X..i|f (arc) |
|00003f30| 7b 09 2f 2a 20 69 66 20 | 77 65 20 68 61 64 20 61 |{./* if |we had a|
|00003f40| 6e 20 6f 72 69 67 69 6e | 61 6c 20 61 72 63 68 69 |n origin|al archi|
|00003f50| 76 65 20 2a 2f 0d 0a 58 | 09 09 09 69 66 20 28 6b |ve */..X|...if (k|
|00003f60| 65 65 70 62 61 6b 29 20 | 7b 09 2f 2a 20 69 66 20 |eepbak) |{./* if |
|00003f70| 61 20 62 61 63 6b 75 70 | 20 69 73 20 77 61 6e 74 |a backup| is want|
|00003f80| 65 64 20 2a 2f 0d 0a 58 | 09 09 09 09 75 6e 6c 69 |ed */..X|....unli|
|00003f90| 6e 6b 28 62 61 6b 6e 61 | 6d 65 29 3b 09 2f 2a 20 |nk(bakna|me);./* |
|00003fa0| 65 72 61 73 65 20 61 6e | 79 20 6f 6c 64 20 63 6f |erase an|y old co|
|00003fb0| 70 69 65 73 20 2a 2f 0d | 0a 58 09 09 09 09 69 66 |pies */.|.X....if|
|00003fc0| 20 28 6d 6f 76 65 28 61 | 72 63 6e 61 6d 65 2c 20 | (move(a|rcname, |
|00003fd0| 62 61 6b 6e 61 6d 65 29 | 29 0d 0a 58 09 09 09 09 |bakname)|)..X....|
|00003fe0| 09 61 62 6f 72 74 28 22 | 43 61 6e 6e 6f 74 20 72 |.abort("|Cannot r|
|00003ff0| 65 6e 61 6d 65 20 25 73 | 20 74 6f 20 25 73 22 2c |ename %s| to %s",|
|00004000| 20 61 72 63 6e 61 6d 65 | 2c 20 62 61 6b 6e 61 6d | arcname|, baknam|
|00004010| 65 29 3b 0d 0a 58 09 09 | 09 09 70 72 69 6e 74 66 |e);..X..|..printf|
|00004020| 28 22 4b 65 65 70 69 6e | 67 20 62 61 63 6b 75 70 |("Keepin|g backup|
|00004030| 20 61 72 63 68 69 76 65 | 3a 20 25 73 5c 6e 22 2c | archive|: %s\n",|
|00004040| 20 62 61 6b 6e 61 6d 65 | 29 3b 0d 0a 58 09 09 09 | bakname|);..X...|
|00004050| 7d 20 65 6c 73 65 20 69 | 66 20 28 75 6e 6c 69 6e |} else i|f (unlin|
|00004060| 6b 28 61 72 63 6e 61 6d | 65 29 29 0d 0a 58 09 09 |k(arcnam|e))..X..|
|00004070| 09 09 61 62 6f 72 74 28 | 22 43 61 6e 6e 6f 74 20 |..abort(|"Cannot |
|00004080| 64 65 6c 65 74 65 20 6f | 6c 64 20 61 72 63 68 69 |delete o|ld archi|
|00004090| 76 65 3a 20 25 73 22 2c | 20 61 72 63 6e 61 6d 65 |ve: %s",| arcname|
|000040a0| 29 3b 0d 0a 58 09 09 7d | 0d 0a 58 09 09 69 66 20 |);..X..}|..X..if |
|000040b0| 28 6d 6f 76 65 28 6e 65 | 77 6e 61 6d 65 2c 20 61 |(move(ne|wname, a|
|000040c0| 72 63 6e 61 6d 65 29 29 | 0d 0a 58 09 09 09 61 62 |rcname))|..X...ab|
|000040d0| 6f 72 74 28 22 43 61 6e | 6e 6f 74 20 6d 6f 76 65 |ort("Can|not move|
|000040e0| 20 25 73 20 74 6f 20 25 | 73 22 2c 20 6e 65 77 6e | %s to %|s", newn|
|000040f0| 61 6d 65 2c 20 61 72 63 | 6e 61 6d 65 29 3b 0d 0a |ame, arc|name);..|
|00004100| 58 23 69 66 09 21 4d 54 | 53 0d 0a 58 09 09 73 65 |X#if.!MT|S..X..se|
|00004110| 74 73 74 61 6d 70 28 61 | 72 63 6e 61 6d 65 2c 20 |tstamp(a|rcname, |
|00004120| 61 72 63 64 61 74 65 2c | 20 61 72 63 74 69 6d 65 |arcdate,| arctime|
|00004130| 29 3b 0d 0a 58 23 65 6e | 64 69 66 0d 0a 58 09 7d |);..X#en|dif..X.}|
|00004140| 0d 0a 58 7d 0d 0a 58 0d | 0a 58 2f 2a 0d 0a 58 20 |..X}..X.|.X/*..X |
|00004150| 2a 20 43 52 43 20 63 6f | 6d 70 75 74 61 74 69 6f |* CRC co|mputatio|
|00004160| 6e 20 6c 6f 67 69 63 0d | 0a 58 20 2a 20 0d 0a 58 |n logic.|.X * ..X|
|00004170| 20 2a 20 54 68 65 20 6c | 6f 67 69 63 20 66 6f 72 | * The l|ogic for|
|00004180| 20 74 68 69 73 20 6d 65 | 74 68 6f 64 20 6f 66 20 | this me|thod of |
|00004190| 63 61 6c 63 75 6c 61 74 | 69 6e 67 20 74 68 65 20 |calculat|ing the |
|000041a0| 43 52 43 20 31 36 20 62 | 69 74 20 70 6f 6c 79 6e |CRC 16 b|it polyn|
|000041b0| 6f 6d 69 61 6c 20 69 73 | 20 74 61 6b 65 6e 0d 0a |omial is| taken..|
|000041c0| 58 20 2a 20 66 72 6f 6d | 20 61 6e 20 61 72 74 69 |X * from| an arti|
|000041d0| 63 6c 65 20 62 79 20 44 | 61 76 69 64 20 53 63 68 |cle by D|avid Sch|
|000041e0| 77 61 64 65 72 65 72 20 | 69 6e 20 74 68 65 20 41 |waderer |in the A|
|000041f0| 70 72 69 6c 20 31 39 38 | 35 20 69 73 73 75 65 20 |pril 198|5 issue |
|00004200| 6f 66 20 50 43 20 54 65 | 63 68 0d 0a 58 20 2a 20 |of PC Te|ch..X * |
|00004210| 4a 6f 75 72 6e 61 6c 2e | 0d 0a 58 20 2a 2f 0d 0a |Journal.|..X */..|
|00004220| 58 0d 0a 58 73 74 61 74 | 69 63 20 73 68 6f 72 74 |X..Xstat|ic short|
|00004230| 20 20 20 20 20 20 63 72 | 63 74 61 62 5b 5d 20 3d | cr|ctab[] =|
|00004240| 09 2f 2a 20 43 52 43 20 | 6c 6f 6f 6b 75 70 20 74 |./* CRC |lookup t|
|00004250| 61 62 6c 65 20 2a 2f 0d | 0a 58 7b 0d 0a 58 20 30 |able */.|.X{..X 0|
|00004260| 78 30 30 30 30 2c 20 30 | 78 43 30 43 31 2c 20 30 |x0000, 0|xC0C1, 0|
|00004270| 78 43 31 38 31 2c 20 30 | 78 30 31 34 30 2c 20 30 |xC181, 0|x0140, 0|
|00004280| 78 43 33 30 31 2c 20 30 | 78 30 33 43 30 2c 20 30 |xC301, 0|x03C0, 0|
|00004290| 78 30 32 38 30 2c 20 30 | 78 43 32 34 31 2c 0d 0a |x0280, 0|xC241,..|
|000042a0| 58 20 30 78 43 36 30 31 | 2c 20 30 78 30 36 43 30 |X 0xC601|, 0x06C0|
|000042b0| 2c 20 30 78 30 37 38 30 | 2c 20 30 78 43 37 34 31 |, 0x0780|, 0xC741|
|000042c0| 2c 20 30 78 30 35 30 30 | 2c 20 30 78 43 35 43 31 |, 0x0500|, 0xC5C1|
|000042d0| 2c 20 30 78 43 34 38 31 | 2c 20 30 78 30 34 34 30 |, 0xC481|, 0x0440|
|000042e0| 2c 0d 0a 58 20 30 78 43 | 43 30 31 2c 20 30 78 30 |,..X 0xC|C01, 0x0|
|000042f0| 43 43 30 2c 20 30 78 30 | 44 38 30 2c 20 30 78 43 |CC0, 0x0|D80, 0xC|
|00004300| 44 34 31 2c 20 30 78 30 | 46 30 30 2c 20 30 78 43 |D41, 0x0|F00, 0xC|
|00004310| 46 43 31 2c 20 30 78 43 | 45 38 31 2c 20 30 78 30 |FC1, 0xC|E81, 0x0|
|00004320| 45 34 30 2c 0d 0a 58 20 | 30 78 30 41 30 30 2c 20 |E40,..X |0x0A00, |
|00004330| 30 78 43 41 43 31 2c 20 | 30 78 43 42 38 31 2c 20 |0xCAC1, |0xCB81, |
|00004340| 30 78 30 42 34 30 2c 20 | 30 78 43 39 30 31 2c 20 |0x0B40, |0xC901, |
|00004350| 30 78 30 39 43 30 2c 20 | 30 78 30 38 38 30 2c 20 |0x09C0, |0x0880, |
|00004360| 30 78 43 38 34 31 2c 0d | 0a 58 20 30 78 44 38 30 |0xC841,.|.X 0xD80|
|00004370| 31 2c 20 30 78 31 38 43 | 30 2c 20 30 78 31 39 38 |1, 0x18C|0, 0x198|
|00004380| 30 2c 20 30 78 44 39 34 | 31 2c 20 30 78 31 42 30 |0, 0xD94|1, 0x1B0|
|00004390| 30 2c 20 30 78 44 42 43 | 31 2c 20 30 78 44 41 38 |0, 0xDBC|1, 0xDA8|
|000043a0| 31 2c 20 30 78 31 41 34 | 30 2c 0d 0a 58 20 30 78 |1, 0x1A4|0,..X 0x|
|000043b0| 31 45 30 30 2c 20 30 78 | 44 45 43 31 2c 20 30 78 |1E00, 0x|DEC1, 0x|
|000043c0| 44 46 38 31 2c 20 30 78 | 31 46 34 30 2c 20 30 78 |DF81, 0x|1F40, 0x|
|000043d0| 44 44 30 31 2c 20 30 78 | 31 44 43 30 2c 20 30 78 |DD01, 0x|1DC0, 0x|
|000043e0| 31 43 38 30 2c 20 30 78 | 44 43 34 31 2c 0d 0a 58 |1C80, 0x|DC41,..X|
|000043f0| 20 30 78 31 34 30 30 2c | 20 30 78 44 34 43 31 2c | 0x1400,| 0xD4C1,|
|00004400| 20 30 78 44 35 38 31 2c | 20 30 78 31 35 34 30 2c | 0xD581,| 0x1540,|
|00004410| 20 30 78 44 37 30 31 2c | 20 30 78 31 37 43 30 2c | 0xD701,| 0x17C0,|
|00004420| 20 30 78 31 36 38 30 2c | 20 30 78 44 36 34 31 2c | 0x1680,| 0xD641,|
|00004430| 0d 0a 58 20 30 78 44 32 | 30 31 2c 20 30 78 31 32 |..X 0xD2|01, 0x12|
|00004440| 43 30 2c 20 30 78 31 33 | 38 30 2c 20 30 78 44 33 |C0, 0x13|80, 0xD3|
|00004450| 34 31 2c 20 30 78 31 31 | 30 30 2c 20 30 78 44 31 |41, 0x11|00, 0xD1|
|00004460| 43 31 2c 20 30 78 44 30 | 38 31 2c 20 30 78 31 30 |C1, 0xD0|81, 0x10|
|00004470| 34 30 2c 0d 0a 58 20 30 | 78 46 30 30 31 2c 20 30 |40,..X 0|xF001, 0|
|00004480| 78 33 30 43 30 2c 20 30 | 78 33 31 38 30 2c 20 30 |x30C0, 0|x3180, 0|
|00004490| 78 46 31 34 31 2c 20 30 | 78 33 33 30 30 2c 20 30 |xF141, 0|x3300, 0|
|000044a0| 78 46 33 43 31 2c 20 30 | 78 46 32 38 31 2c 20 30 |xF3C1, 0|xF281, 0|
|000044b0| 78 33 32 34 30 2c 0d 0a | 58 20 30 78 33 36 30 30 |x3240,..|X 0x3600|
|000044c0| 2c 20 30 78 46 36 43 31 | 2c 20 30 78 46 37 38 31 |, 0xF6C1|, 0xF781|
|000044d0| 2c 20 30 78 33 37 34 30 | 2c 20 30 78 46 35 30 31 |, 0x3740|, 0xF501|
|000044e0| 2c 20 30 78 33 35 43 30 | 2c 20 30 78 33 34 38 30 |, 0x35C0|, 0x3480|
|000044f0| 2c 20 30 78 46 34 34 31 | 2c 0d 0a 58 20 30 78 33 |, 0xF441|,..X 0x3|
|00004500| 43 30 30 2c 20 30 78 46 | 43 43 31 2c 20 30 78 46 |C00, 0xF|CC1, 0xF|
|00004510| 44 38 31 2c 20 30 78 33 | 44 34 30 2c 20 30 78 46 |D81, 0x3|D40, 0xF|
|00004520| 46 30 31 2c 20 30 78 33 | 46 43 30 2c 20 30 78 33 |F01, 0x3|FC0, 0x3|
|00004530| 45 38 30 2c 20 30 78 46 | 45 34 31 2c 0d 0a 58 20 |E80, 0xF|E41,..X |
|00004540| 30 78 46 41 30 31 2c 20 | 30 78 33 41 43 30 2c 20 |0xFA01, |0x3AC0, |
|00004550| 30 78 33 42 38 30 2c 20 | 30 78 46 42 34 31 2c 20 |0x3B80, |0xFB41, |
|00004560| 30 78 33 39 30 30 2c 20 | 30 78 46 39 43 31 2c 20 |0x3900, |0xF9C1, |
|00004570| 30 78 46 38 38 31 2c 20 | 30 78 33 38 34 30 2c 0d |0xF881, |0x3840,.|
|00004580| 0a 58 20 30 78 32 38 30 | 30 2c 20 30 78 45 38 43 |.X 0x280|0, 0xE8C|
|00004590| 31 2c 20 30 78 45 39 38 | 31 2c 20 30 78 32 39 34 |1, 0xE98|1, 0x294|
|000045a0| 30 2c 20 30 78 45 42 30 | 31 2c 20 30 78 32 42 43 |0, 0xEB0|1, 0x2BC|
|000045b0| 30 2c 20 30 78 32 41 38 | 30 2c 20 30 78 45 41 34 |0, 0x2A8|0, 0xEA4|
|000045c0| 31 2c 0d 0a 58 20 30 78 | 45 45 30 31 2c 20 30 78 |1,..X 0x|EE01, 0x|
|000045d0| 32 45 43 30 2c 20 30 78 | 32 46 38 30 2c 20 30 78 |2EC0, 0x|2F80, 0x|
|000045e0| 45 46 34 31 2c 20 30 78 | 32 44 30 30 2c 20 30 78 |EF41, 0x|2D00, 0x|
|000045f0| 45 44 43 31 2c 20 30 78 | 45 43 38 31 2c 20 30 78 |EDC1, 0x|EC81, 0x|
|00004600| 32 43 34 30 2c 0d 0a 58 | 20 30 78 45 34 30 31 2c |2C40,..X| 0xE401,|
|00004610| 20 30 78 32 34 43 30 2c | 20 30 78 32 35 38 30 2c | 0x24C0,| 0x2580,|
|00004620| 20 30 78 45 35 34 31 2c | 20 30 78 32 37 30 30 2c | 0xE541,| 0x2700,|
|00004630| 20 30 78 45 37 43 31 2c | 20 30 78 45 36 38 31 2c | 0xE7C1,| 0xE681,|
|00004640| 20 30 78 32 36 34 30 2c | 0d 0a 58 20 30 78 32 32 | 0x2640,|..X 0x22|
|00004650| 30 30 2c 20 30 78 45 32 | 43 31 2c 20 30 78 45 33 |00, 0xE2|C1, 0xE3|
|00004660| 38 31 2c 20 30 78 32 33 | 34 30 2c 20 30 78 45 31 |81, 0x23|40, 0xE1|
|00004670| 30 31 2c 20 30 78 32 31 | 43 30 2c 20 30 78 32 30 |01, 0x21|C0, 0x20|
|00004680| 38 30 2c 20 30 78 45 30 | 34 31 2c 0d 0a 58 20 30 |80, 0xE0|41,..X 0|
|00004690| 78 41 30 30 31 2c 20 30 | 78 36 30 43 30 2c 20 30 |xA001, 0|x60C0, 0|
|000046a0| 78 36 31 38 30 2c 20 30 | 78 41 31 34 31 2c 20 30 |x6180, 0|xA141, 0|
|000046b0| 78 36 33 30 30 2c 20 30 | 78 41 33 43 31 2c 20 30 |x6300, 0|xA3C1, 0|
|000046c0| 78 41 32 38 31 2c 20 30 | 78 36 32 34 30 2c 0d 0a |xA281, 0|x6240,..|
|000046d0| 58 20 30 78 36 36 30 30 | 2c 20 30 78 41 36 43 31 |X 0x6600|, 0xA6C1|
|000046e0| 2c 20 30 78 41 37 38 31 | 2c 20 30 78 36 37 34 30 |, 0xA781|, 0x6740|
|000046f0| 2c 20 30 78 41 35 30 31 | 2c 20 30 78 36 35 43 30 |, 0xA501|, 0x65C0|
|00004700| 2c 20 30 78 36 34 38 30 | 2c 20 30 78 41 34 34 31 |, 0x6480|, 0xA441|
|00004710| 2c 0d 0a 58 20 30 78 36 | 43 30 30 2c 20 30 78 41 |,..X 0x6|C00, 0xA|
|00004720| 43 43 31 2c 20 30 78 41 | 44 38 31 2c 20 30 78 36 |CC1, 0xA|D81, 0x6|
|00004730| 44 34 30 2c 20 30 78 41 | 46 30 31 2c 20 30 78 36 |D40, 0xA|F01, 0x6|
|00004740| 46 43 30 2c 20 30 78 36 | 45 38 30 2c 20 30 78 41 |FC0, 0x6|E80, 0xA|
|00004750| 45 34 31 2c 0d 0a 58 20 | 30 78 41 41 30 31 2c 20 |E41,..X |0xAA01, |
|00004760| 30 78 36 41 43 30 2c 20 | 30 78 36 42 38 30 2c 20 |0x6AC0, |0x6B80, |
|00004770| 30 78 41 42 34 31 2c 20 | 30 78 36 39 30 30 2c 20 |0xAB41, |0x6900, |
|00004780| 30 78 41 39 43 31 2c 20 | 30 78 41 38 38 31 2c 20 |0xA9C1, |0xA881, |
|00004790| 30 78 36 38 34 30 2c 0d | 0a 58 20 30 78 37 38 30 |0x6840,.|.X 0x780|
|000047a0| 30 2c 20 30 78 42 38 43 | 31 2c 20 30 78 42 39 38 |0, 0xB8C|1, 0xB98|
|000047b0| 31 2c 20 30 78 37 39 34 | 30 2c 20 30 78 42 42 30 |1, 0x794|0, 0xBB0|
|000047c0| 31 2c 20 30 78 37 42 43 | 30 2c 20 30 78 37 41 38 |1, 0x7BC|0, 0x7A8|
|000047d0| 30 2c 20 30 78 42 41 34 | 31 2c 0d 0a 58 20 30 78 |0, 0xBA4|1,..X 0x|
|000047e0| 42 45 30 31 2c 20 30 78 | 37 45 43 30 2c 20 30 78 |BE01, 0x|7EC0, 0x|
|000047f0| 37 46 38 30 2c 20 30 78 | 42 46 34 31 2c 20 30 78 |7F80, 0x|BF41, 0x|
|00004800| 37 44 30 30 2c 20 30 78 | 42 44 43 31 2c 20 30 78 |7D00, 0x|BDC1, 0x|
|00004810| 42 43 38 31 2c 20 30 78 | 37 43 34 30 2c 0d 0a 58 |BC81, 0x|7C40,..X|
|00004820| 20 30 78 42 34 30 31 2c | 20 30 78 37 34 43 30 2c | 0xB401,| 0x74C0,|
|00004830| 20 30 78 37 35 38 30 2c | 20 30 78 42 35 34 31 2c | 0x7580,| 0xB541,|
|00004840| 20 30 78 37 37 30 30 2c | 20 30 78 42 37 43 31 2c | 0x7700,| 0xB7C1,|
|00004850| 20 30 78 42 36 38 31 2c | 20 30 78 37 36 34 30 2c | 0xB681,| 0x7640,|
|00004860| 0d 0a 58 20 30 78 37 32 | 30 30 2c 20 30 78 42 32 |..X 0x72|00, 0xB2|
|00004870| 43 31 2c 20 30 78 42 33 | 38 31 2c 20 30 78 37 33 |C1, 0xB3|81, 0x73|
|00004880| 34 30 2c 20 30 78 42 31 | 30 31 2c 20 30 78 37 31 |40, 0xB1|01, 0x71|
|00004890| 43 30 2c 20 30 78 37 30 | 38 30 2c 20 30 78 42 30 |C0, 0x70|80, 0xB0|
|000048a0| 34 31 2c 0d 0a 58 20 30 | 78 35 30 30 30 2c 20 30 |41,..X 0|x5000, 0|
|000048b0| 78 39 30 43 31 2c 20 30 | 78 39 31 38 31 2c 20 30 |x90C1, 0|x9181, 0|
|000048c0| 78 35 31 34 30 2c 20 30 | 78 39 33 30 31 2c 20 30 |x5140, 0|x9301, 0|
|000048d0| 78 35 33 43 30 2c 20 30 | 78 35 32 38 30 2c 20 30 |x53C0, 0|x5280, 0|
|000048e0| 78 39 32 34 31 2c 0d 0a | 58 20 30 78 39 36 30 31 |x9241,..|X 0x9601|
|000048f0| 2c 20 30 78 35 36 43 30 | 2c 20 30 78 35 37 38 30 |, 0x56C0|, 0x5780|
|00004900| 2c 20 30 78 39 37 34 31 | 2c 20 30 78 35 35 30 30 |, 0x9741|, 0x5500|
|00004910| 2c 20 30 78 39 35 43 31 | 2c 20 30 78 39 34 38 31 |, 0x95C1|, 0x9481|
|00004920| 2c 20 30 78 35 34 34 30 | 2c 0d 0a 58 20 30 78 39 |, 0x5440|,..X 0x9|
|00004930| 43 30 31 2c 20 30 78 35 | 43 43 30 2c 20 30 78 35 |C01, 0x5|CC0, 0x5|
|00004940| 44 38 30 2c 20 30 78 39 | 44 34 31 2c 20 30 78 35 |D80, 0x9|D41, 0x5|
|00004950| 46 30 30 2c 20 30 78 39 | 46 43 31 2c 20 30 78 39 |F00, 0x9|FC1, 0x9|
|00004960| 45 38 31 2c 20 30 78 35 | 45 34 30 2c 0d 0a 58 20 |E81, 0x5|E40,..X |
|00004970| 30 78 35 41 30 30 2c 20 | 30 78 39 41 43 31 2c 20 |0x5A00, |0x9AC1, |
|00004980| 30 78 39 42 38 31 2c 20 | 30 78 35 42 34 30 2c 20 |0x9B81, |0x5B40, |
|00004990| 30 78 39 39 30 31 2c 20 | 30 78 35 39 43 30 2c 20 |0x9901, |0x59C0, |
|000049a0| 30 78 35 38 38 30 2c 20 | 30 78 39 38 34 31 2c 0d |0x5880, |0x9841,.|
|000049b0| 0a 58 20 30 78 38 38 30 | 31 2c 20 30 78 34 38 43 |.X 0x880|1, 0x48C|
|000049c0| 30 2c 20 30 78 34 39 38 | 30 2c 20 30 78 38 39 34 |0, 0x498|0, 0x894|
|000049d0| 31 2c 20 30 78 34 42 30 | 30 2c 20 30 78 38 42 43 |1, 0x4B0|0, 0x8BC|
|000049e0| 31 2c 20 30 78 38 41 38 | 31 2c 20 30 78 34 41 34 |1, 0x8A8|1, 0x4A4|
|000049f0| 30 2c 0d 0a 58 20 30 78 | 34 45 30 30 2c 20 30 78 |0,..X 0x|4E00, 0x|
|00004a00| 38 45 43 31 2c 20 30 78 | 38 46 38 31 2c 20 30 78 |8EC1, 0x|8F81, 0x|
|00004a10| 34 46 34 30 2c 20 30 78 | 38 44 30 31 2c 20 30 78 |4F40, 0x|8D01, 0x|
|00004a20| 34 44 43 30 2c 20 30 78 | 34 43 38 30 2c 20 30 78 |4DC0, 0x|4C80, 0x|
|00004a30| 38 43 34 31 2c 0d 0a 58 | 20 30 78 34 34 30 30 2c |8C41,..X| 0x4400,|
|00004a40| 20 30 78 38 34 43 31 2c | 20 30 78 38 35 38 31 2c | 0x84C1,| 0x8581,|
|00004a50| 20 30 78 34 35 34 30 2c | 20 30 78 38 37 30 31 2c | 0x4540,| 0x8701,|
|00004a60| 20 30 78 34 37 43 30 2c | 20 30 78 34 36 38 30 2c | 0x47C0,| 0x4680,|
|00004a70| 20 30 78 38 36 34 31 2c | 0d 0a 58 20 30 78 38 32 | 0x8641,|..X 0x82|
|00004a80| 30 31 2c 20 30 78 34 32 | 43 30 2c 20 30 78 34 33 |01, 0x42|C0, 0x43|
|00004a90| 38 30 2c 20 30 78 38 33 | 34 31 2c 20 30 78 34 31 |80, 0x83|41, 0x41|
|00004aa0| 30 30 2c 20 30 78 38 31 | 43 31 2c 20 30 78 38 30 |00, 0x81|C1, 0x80|
|00004ab0| 38 31 2c 20 30 78 34 30 | 34 30 0d 0a 58 7d 3b 0d |81, 0x40|40..X};.|
|00004ac0| 0a 58 0d 0a 58 69 6e 74 | 0d 0a 58 61 64 64 63 72 |.X..Xint|..Xaddcr|
|00004ad0| 63 28 63 72 63 2c 20 63 | 29 09 09 09 2f 2a 20 75 |c(crc, c|).../* u|
|00004ae0| 70 64 61 74 65 20 61 20 | 43 52 43 20 63 68 65 63 |pdate a |CRC chec|
|00004af0| 6b 20 2a 2f 0d 0a 58 09 | 69 6e 74 20 20 20 20 20 |k */..X.|int |
|00004b00| 20 20 20 20 20 20 20 20 | 63 72 63 3b 09 2f 2a 20 | |crc;./* |
|00004b10| 72 75 6e 6e 69 6e 67 20 | 43 52 43 20 76 61 6c 75 |running |CRC valu|
|00004b20| 65 20 2a 2f 0d 0a 58 09 | 75 6e 73 69 67 6e 65 64 |e */..X.|unsigned|
|00004b30| 20 63 68 61 72 20 20 20 | 63 3b 09 2f 2a 20 63 68 | char |c;./* ch|
|00004b40| 61 72 61 63 74 65 72 20 | 74 6f 20 61 64 64 20 2a |aracter |to add *|
|00004b50| 2f 0d 0a 58 7b 0d 0a 58 | 09 72 65 74 75 72 6e 20 |/..X{..X|.return |
|00004b60| 28 28 63 72 63 20 3e 3e | 20 38 29 20 26 20 30 78 |((crc >>| 8) & 0x|
|00004b70| 30 30 66 66 29 20 5e 20 | 63 72 63 74 61 62 5b 28 |00ff) ^ |crctab[(|
|00004b80| 63 72 63 20 5e 20 63 29 | 20 26 20 30 78 30 30 66 |crc ^ c)| & 0x00f|
|00004b90| 66 5d 3b 0d 0a 58 7d 0d | 0a 5f 5f 5f 5f 5f 5f 5f |f];..X}.|._______|
|00004ba0| 5f 54 68 69 73 5f 49 73 | 5f 54 68 65 5f 45 4e 44 |_This_Is|_The_END|
|00004bb0| 5f 5f 5f 5f 5f 5f 5f 5f | 0d 0a 69 66 20 74 65 73 |________|..if tes|
|00004bc0| 74 20 60 77 63 20 2d 63 | 20 3c 20 61 72 63 73 76 |t `wc -c| < arcsv|
|00004bd0| 63 2e 63 60 20 2d 6e 65 | 20 20 20 20 20 34 36 38 |c.c` -ne| 468|
|00004be0| 30 3b 20 74 68 65 6e 0d | 0a 09 65 63 68 6f 20 27 |0; then.|..echo '|
|00004bf0| 73 68 61 72 3a 20 61 72 | 63 73 76 63 2e 63 20 77 |shar: ar|csvc.c w|
|00004c00| 61 73 20 64 61 6d 61 67 | 65 64 20 64 75 72 69 6e |as damag|ed durin|
|00004c10| 67 20 74 72 61 6e 73 69 | 74 20 28 73 68 6f 75 6c |g transi|t (shoul|
|00004c20| 64 20 68 61 76 65 20 62 | 65 65 6e 20 20 20 20 20 |d have b|een |
|00004c30| 34 36 38 30 20 62 79 74 | 65 73 29 27 0d 0a 66 69 |4680 byt|es)'..fi|
|00004c40| 0d 0a 66 69 09 09 3b 20 | 3a 20 65 6e 64 20 6f 66 |..fi..; |: end of|
|00004c50| 20 6f 76 65 72 77 72 69 | 74 69 6e 67 20 63 68 65 | overwri|ting che|
|00004c60| 63 6b 0d 0a 65 63 68 6f | 20 27 78 20 2d 20 61 72 |ck..echo| 'x - ar|
|00004c70| 63 74 73 74 2e 63 27 0d | 0a 69 66 20 74 65 73 74 |ctst.c'.|.if test|
|00004c80| 20 2d 66 20 61 72 63 74 | 73 74 2e 63 3b 20 74 68 | -f arct|st.c; th|
|00004c90| 65 6e 20 65 63 68 6f 20 | 27 73 68 61 72 3a 20 6e |en echo |'shar: n|
|00004ca0| 6f 74 20 6f 76 65 72 77 | 72 69 74 69 6e 67 20 61 |ot overw|riting a|
|00004cb0| 72 63 74 73 74 2e 63 27 | 3b 20 65 6c 73 65 0d 0a |rctst.c'|; else..|
|00004cc0| 73 65 64 20 27 73 2f 5e | 58 2f 2f 27 20 3c 3c 20 |sed 's/^|X//' << |
|00004cd0| 27 5f 5f 5f 5f 5f 5f 5f | 5f 54 68 69 73 5f 49 73 |'_______|_This_Is|
|00004ce0| 5f 54 68 65 5f 45 4e 44 | 5f 5f 5f 5f 5f 5f 5f 5f |_The_END|________|
|00004cf0| 27 20 3e 20 61 72 63 74 | 73 74 2e 63 0d 0a 58 2f |' > arct|st.c..X/|
|00004d00| 2a 0d 0a 58 20 2a 20 24 | 48 65 61 64 65 72 3a 20 |*..X * $|Header: |
|00004d10| 61 72 63 74 73 74 2e 63 | 2c 76 20 31 2e 34 20 38 |arctst.c|,v 1.4 8|
|00004d20| 38 2f 30 34 2f 31 39 20 | 30 31 3a 34 30 3a 32 38 |8/04/19 |01:40:28|
|00004d30| 20 68 79 63 20 45 78 70 | 20 24 0d 0a 58 20 2a 2f | hyc Exp| $..X */|
|00004d40| 0d 0a 58 0d 0a 58 2f 2a | 0d 0a 58 20 2a 20 41 52 |..X..X/*|..X * AR|
|00004d50| 43 20 2d 20 41 72 63 68 | 69 76 65 20 75 74 69 6c |C - Arch|ive util|
|00004d60| 69 74 79 20 2d 20 41 52 | 43 54 53 54 0d 0a 58 20 |ity - AR|CTST..X |
|00004d70| 2a 20 0d 0a 58 20 2a 20 | 56 65 72 73 69 6f 6e 20 |* ..X * |Version |
|00004d80| 32 2e 31 32 2c 20 63 72 | 65 61 74 65 64 20 6f 6e |2.12, cr|eated on|
|00004d90| 20 30 32 2f 30 33 2f 38 | 36 20 61 74 20 32 33 3a | 02/03/8|6 at 23:|
|00004da0| 30 30 3a 34 30 0d 0a 58 | 20 2a 20 0d 0a 58 20 2a |00:40..X| * ..X *|
|00004db0| 20 28 43 29 20 43 4f 50 | 59 52 49 47 48 54 20 31 | (C) COP|YRIGHT 1|
|00004dc0| 39 38 35 20 62 79 20 53 | 79 73 74 65 6d 20 45 6e |985 by S|ystem En|
|00004dd0| 68 61 6e 63 65 6d 65 6e | 74 20 41 73 73 6f 63 69 |hancemen|t Associ|
|00004de0| 61 74 65 73 3b 20 41 4c | 4c 20 52 49 47 48 54 53 |ates; AL|L RIGHTS|
|00004df0| 20 52 45 53 45 52 56 45 | 44 0d 0a 58 20 2a 20 0d | RESERVE|D..X * .|
|00004e00| 0a 58 20 2a 20 42 79 3a | 20 20 54 68 6f 6d 20 48 |.X * By:| Thom H|
|00004e10| 65 6e 64 65 72 73 6f 6e | 0d 0a 58 20 2a 20 0d 0a |enderson|..X * ..|
|00004e20| 58 20 2a 20 44 65 73 63 | 72 69 70 74 69 6f 6e 3a |X * Desc|ription:|
|00004e30| 20 54 68 69 73 20 66 69 | 6c 65 20 63 6f 6e 74 61 | This fi|le conta|
|00004e40| 69 6e 73 20 74 68 65 20 | 72 6f 75 74 69 6e 65 73 |ins the |routines|
|00004e50| 20 75 73 65 64 20 74 6f | 20 74 65 73 74 20 61 72 | used to| test ar|
|00004e60| 63 68 69 76 65 20 69 6e | 74 65 67 72 69 74 79 2e |chive in|tegrity.|
|00004e70| 0d 0a 58 20 2a 20 0d 0a | 58 20 2a 20 4c 61 6e 67 |..X * ..|X * Lang|
|00004e80| 75 61 67 65 3a 20 43 6f | 6d 70 75 74 65 72 20 49 |uage: Co|mputer I|
|00004e90| 6e 6e 6f 76 61 74 69 6f | 6e 73 20 4f 70 74 69 6d |nnovatio|ns Optim|
|00004ea0| 69 7a 69 6e 67 20 43 38 | 36 0d 0a 58 20 2a 2f 0d |izing C8|6..X */.|
|00004eb0| 0a 58 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |.X#inclu|de <stdi|
|00004ec0| 6f 2e 68 3e 0d 0a 58 23 | 69 6e 63 6c 75 64 65 20 |o.h>..X#|include |
|00004ed0| 22 61 72 63 2e 68 22 0d | 0a 58 0d 0a 58 76 6f 69 |"arc.h".|.X..Xvoi|
|00004ee0| 64 09 6f 70 65 6e 61 72 | 63 28 29 3b 0d 0a 58 69 |d.openar|c();..Xi|
|00004ef0| 6e 74 09 72 65 61 64 68 | 64 72 28 29 2c 20 75 6e |nt.readh|dr(), un|
|00004f00| 70 61 63 6b 28 29 3b 0d | 0a 58 0d 0a 58 76 6f 69 |pack();.|.X..Xvoi|
|00004f10| 64 0d 0a 58 74 73 74 61 | 72 63 28 29 0d 0a 58 7b |d..Xtsta|rc()..X{|
|00004f20| 09 09 09 09 2f 2a 20 74 | 65 73 74 20 69 6e 74 65 |..../* t|est inte|
|00004f30| 67 72 69 74 79 20 6f 66 | 20 61 6e 20 61 72 63 68 |grity of| an arch|
|00004f40| 69 76 65 20 2a 2f 0d 0a | 58 09 73 74 72 75 63 74 |ive */..|X.struct|
|00004f50| 20 68 65 61 64 73 20 20 | 20 20 68 64 72 3b 09 2f | heads | hdr;./|
|00004f60| 2a 20 66 69 6c 65 20 68 | 65 61 64 65 72 20 2a 2f |* file h|eader */|
|00004f70| 0d 0a 58 09 6c 6f 6e 67 | 20 20 20 20 20 20 20 20 |..X.long| |
|00004f80| 20 20 20 20 61 72 63 73 | 69 7a 65 2c 20 66 74 65 | arcs|ize, fte|
|00004f90| 6c 6c 28 29 3b 09 2f 2a | 20 61 72 63 68 69 76 65 |ll();./*| archive|
|00004fa0| 20 73 69 7a 65 20 2a 2f | 0d 0a 58 0d 0a 58 09 6f | size */|..X..X.o|
|00004fb0| 70 65 6e 61 72 63 28 30 | 29 3b 09 09 2f 2a 20 6f |penarc(0|);../* o|
|00004fc0| 70 65 6e 20 61 72 63 68 | 69 76 65 20 66 6f 72 20 |pen arch|ive for |
|00004fd0| 72 65 61 64 69 6e 67 20 | 2a 2f 0d 0a 58 09 66 73 |reading |*/..X.fs|
|00004fe0| 65 65 6b 28 61 72 63 2c | 20 30 4c 2c 20 32 29 3b |eek(arc,| 0L, 2);|
|00004ff0| 09 2f 2a 20 6d 6f 76 65 | 20 74 6f 20 65 6e 64 20 |./* move| to end |
|00005000| 6f 66 20 61 72 63 68 69 | 76 65 20 2a 2f 0d 0a 58 |of archi|ve */..X|
|00005010| 09 61 72 63 73 69 7a 65 | 20 3d 20 66 74 65 6c 6c |.arcsize| = ftell|
|00005020| 28 61 72 63 29 3b 09 2f | 2a 20 73 65 65 20 68 6f |(arc);./|* see ho|
|00005030| 77 20 62 69 67 20 69 74 | 20 69 73 20 2a 2f 0d 0a |w big it| is */..|
|00005040| 58 09 66 73 65 65 6b 28 | 61 72 63 2c 20 30 4c 2c |X.fseek(|arc, 0L,|
|00005050| 20 30 29 3b 09 2f 2a 20 | 72 65 74 75 72 6e 20 74 | 0);./* |return t|
|00005060| 6f 20 74 6f 70 20 6f 66 | 20 61 72 63 68 69 76 65 |o top of| archive|
|00005070| 20 2a 2f 0d 0a 58 0d 0a | 58 09 77 68 69 6c 65 20 | */..X..|X.while |
|00005080| 28 72 65 61 64 68 64 72 | 28 26 68 64 72 2c 20 61 |(readhdr|(&hdr, a|
|00005090| 72 63 29 29 20 7b 0d 0a | 58 09 09 69 66 20 28 66 |rc)) {..|X..if (f|
|000050a0| 74 65 6c 6c 28 61 72 63 | 29 20 2b 20 68 64 72 2e |tell(arc|) + hdr.|
|000050b0| 73 69 7a 65 20 3e 20 61 | 72 63 73 69 7a 65 29 20 |size > a|rcsize) |
|000050c0| 7b 0d 0a 58 09 09 09 70 | 72 69 6e 74 66 28 22 41 |{..X...p|rintf("A|
|000050d0| 72 63 68 69 76 65 20 74 | 72 75 6e 63 61 74 65 64 |rchive t|runcated|
|000050e0| 20 69 6e 20 66 69 6c 65 | 20 25 73 5c 6e 22 2c 20 | in file| %s\n", |
|000050f0| 68 64 72 2e 6e 61 6d 65 | 29 3b 0d 0a 58 09 09 09 |hdr.name|);..X...|
|00005100| 6e 65 72 72 73 2b 2b 3b | 0d 0a 58 09 09 09 62 72 |nerrs++;|..X...br|
|00005110| 65 61 6b 3b 0d 0a 58 09 | 09 7d 20 65 6c 73 65 20 |eak;..X.|.} else |
|00005120| 7b 0d 0a 58 09 09 09 70 | 72 69 6e 74 66 28 22 54 |{..X...p|rintf("T|
|00005130| 65 73 74 69 6e 67 20 66 | 69 6c 65 3a 20 25 2d 31 |esting f|ile: %-1|
|00005140| 32 73 20 20 22 2c 20 68 | 64 72 2e 6e 61 6d 65 29 |2s ", h|dr.name)|
|00005150| 3b 0d 0a 58 09 09 09 66 | 66 6c 75 73 68 28 73 74 |;..X...f|flush(st|
|00005160| 64 6f 75 74 29 3b 0d 0a | 58 09 09 09 69 66 20 28 |dout);..|X...if (|
|00005170| 75 6e 70 61 63 6b 28 61 | 72 63 2c 20 4e 55 4c 4c |unpack(a|rc, NULL|
|00005180| 2c 20 26 68 64 72 29 29 | 0d 0a 58 09 09 09 09 6e |, &hdr))|..X....n|
|00005190| 65 72 72 73 2b 2b 3b 0d | 0a 58 09 09 09 65 6c 73 |errs++;.|.X...els|
|000051a0| 65 0d 0a 58 09 09 09 09 | 70 72 69 6e 74 66 28 22 |e..X....|printf("|
|000051b0| 6f 6b 61 79 5c 6e 22 29 | 3b 0d 0a 58 09 09 7d 0d |okay\n")|;..X..}.|
|000051c0| 0a 58 09 7d 0d 0a 58 0d | 0a 58 09 69 66 20 28 6e |.X.}..X.|.X.if (n|
|000051d0| 65 72 72 73 20 3c 20 31 | 29 0d 0a 58 09 09 70 72 |errs < 1|)..X..pr|
|000051e0| 69 6e 74 66 28 22 4e 6f | 20 65 72 72 6f 72 73 20 |intf("No| errors |
|000051f0| 64 65 74 65 63 74 65 64 | 5c 6e 22 29 3b 0d 0a 58 |detected|\n");..X|
|00005200| 09 65 6c 73 65 20 69 66 | 20 28 6e 65 72 72 73 20 |.else if| (nerrs |
|00005210| 3d 3d 20 31 29 0d 0a 58 | 09 09 70 72 69 6e 74 66 |== 1)..X|..printf|
|00005220| 28 22 4f 6e 65 20 65 72 | 72 6f 72 20 64 65 74 65 |("One er|ror dete|
|00005230| 63 74 65 64 5c 6e 22 29 | 3b 0d 0a 58 09 65 6c 73 |cted\n")|;..X.els|
|00005240| 65 0d 0a 58 09 09 70 72 | 69 6e 74 66 28 22 25 64 |e..X..pr|intf("%d|
|00005250| 20 65 72 72 6f 72 73 20 | 64 65 74 65 63 74 65 64 | errors |detected|
|00005260| 5c 6e 22 2c 20 6e 65 72 | 72 73 29 3b 0d 0a 58 7d |\n", ner|rs);..X}|
|00005270| 0d 0a 5f 5f 5f 5f 5f 5f | 5f 5f 54 68 69 73 5f 49 |..______|__This_I|
|00005280| 73 5f 54 68 65 5f 45 4e | 44 5f 5f 5f 5f 5f 5f 5f |s_The_EN|D_______|
|00005290| 5f 0d 0a 69 66 20 74 65 | 73 74 20 60 77 63 20 2d |_..if te|st `wc -|
|000052a0| 63 20 3c 20 61 72 63 74 | 73 74 2e 63 60 20 2d 6e |c < arct|st.c` -n|
|000052b0| 65 20 20 20 20 20 31 32 | 38 34 3b 20 74 68 65 6e |e 12|84; then|
|000052c0| 0d 0a 09 65 63 68 6f 20 | 27 73 68 61 72 3a 20 61 |...echo |'shar: a|
|000052d0| 72 63 74 73 74 2e 63 20 | 77 61 73 20 64 61 6d 61 |rctst.c |was dama|
|000052e0| 67 65 64 20 64 75 72 69 | 6e 67 20 74 72 61 6e 73 |ged duri|ng trans|
|000052f0| 69 74 20 28 73 68 6f 75 | 6c 64 20 68 61 76 65 20 |it (shou|ld have |
|00005300| 62 65 65 6e 20 20 20 20 | 20 31 32 38 34 20 62 79 |been | 1284 by|
|00005310| 74 65 73 29 27 0d 0a 66 | 69 0d 0a 66 69 09 09 3b |tes)'..f|i..fi..;|
|00005320| 20 3a 20 65 6e 64 20 6f | 66 20 6f 76 65 72 77 72 | : end o|f overwr|
|00005330| 69 74 69 6e 67 20 63 68 | 65 63 6b 0d 0a 65 63 68 |iting ch|eck..ech|
|00005340| 6f 20 27 78 20 2d 20 61 | 72 63 75 6e 70 2e 63 27 |o 'x - a|rcunp.c'|
|00005350| 0d 0a 69 66 20 74 65 73 | 74 20 2d 66 20 61 72 63 |..if tes|t -f arc|
|00005360| 75 6e 70 2e 63 3b 20 74 | 68 65 6e 20 65 63 68 6f |unp.c; t|hen echo|
|00005370| 20 27 73 68 61 72 3a 20 | 6e 6f 74 20 6f 76 65 72 | 'shar: |not over|
|00005380| 77 72 69 74 69 6e 67 20 | 61 72 63 75 6e 70 2e 63 |writing |arcunp.c|
|00005390| 27 3b 20 65 6c 73 65 0d | 0a 73 65 64 20 27 73 2f |'; else.|.sed 's/|
|000053a0| 5e 58 2f 2f 27 20 3c 3c | 20 27 5f 5f 5f 5f 5f 5f |^X//' <<| '______|
|000053b0| 5f 5f 54 68 69 73 5f 49 | 73 5f 54 68 65 5f 45 4e |__This_I|s_The_EN|
|000053c0| 44 5f 5f 5f 5f 5f 5f 5f | 5f 27 20 3e 20 61 72 63 |D_______|_' > arc|
|000053d0| 75 6e 70 2e 63 0d 0a 58 | 2f 2a 0d 0a 58 20 2a 20 |unp.c..X|/*..X * |
|000053e0| 24 48 65 61 64 65 72 3a | 20 61 72 63 75 6e 70 2e |$Header:| arcunp.|
|000053f0| 63 2c 76 20 31 2e 37 20 | 38 38 2f 30 36 2f 31 38 |c,v 1.7 |88/06/18|
|00005400| 20 30 33 3a 31 32 3a 33 | 36 20 68 79 63 20 4c 6f | 03:12:3|6 hyc Lo|
|00005410| 63 6b 65 64 20 24 0d 0a | 58 20 2a 2f 0d 0a 58 0d |cked $..|X */..X.|
|00005420| 0a 58 2f 2a 0d 0a 58 20 | 2a 20 41 52 43 20 2d 20 |.X/*..X |* ARC - |
|00005430| 41 72 63 68 69 76 65 20 | 75 74 69 6c 69 74 79 20 |Archive |utility |
|00005440| 2d 20 41 52 43 55 4e 50 | 0d 0a 58 20 2a 20 0d 0a |- ARCUNP|..X * ..|
|00005450| 58 20 2a 20 56 65 72 73 | 69 6f 6e 20 33 2e 31 37 |X * Vers|ion 3.17|
|00005460| 2c 20 63 72 65 61 74 65 | 64 20 6f 6e 20 30 32 2f |, create|d on 02/|
|00005470| 31 33 2f 38 36 20 61 74 | 20 31 30 3a 32 30 3a 30 |13/86 at| 10:20:0|
|00005480| 38 0d 0a 58 20 2a 20 0d | 0a 58 20 2a 20 28 43 29 |8..X * .|.X * (C)|
|00005490| 20 43 4f 50 59 52 49 47 | 48 54 20 31 39 38 35 20 | COPYRIG|HT 1985 |
|000054a0| 62 79 20 53 79 73 74 65 | 6d 20 45 6e 68 61 6e 63 |by Syste|m Enhanc|
|000054b0| 65 6d 65 6e 74 20 41 73 | 73 6f 63 69 61 74 65 73 |ement As|sociates|
|000054c0| 3b 20 41 4c 4c 20 52 49 | 47 48 54 53 20 52 45 53 |; ALL RI|GHTS RES|
|000054d0| 45 52 56 45 44 0d 0a 58 | 20 2a 20 0d 0a 58 20 2a |ERVED..X| * ..X *|
|000054e0| 20 42 79 3a 20 20 54 68 | 6f 6d 20 48 65 6e 64 65 | By: Th|om Hende|
|000054f0| 72 73 6f 6e 0d 0a 58 20 | 2a 20 0d 0a 58 20 2a 20 |rson..X |* ..X * |
|00005500| 44 65 73 63 72 69 70 74 | 69 6f 6e 3a 20 54 68 69 |Descript|ion: Thi|
|00005510| 73 20 66 69 6c 65 20 63 | 6f 6e 74 61 69 6e 73 20 |s file c|ontains |
|00005520| 74 68 65 20 72 6f 75 74 | 69 6e 65 73 20 75 73 65 |the rout|ines use|
|00005530| 64 20 74 6f 20 65 78 70 | 61 6e 64 20 61 20 66 69 |d to exp|and a fi|
|00005540| 6c 65 20 77 68 65 6e 0d | 0a 58 20 2a 20 74 61 6b |le when.|.X * tak|
|00005550| 69 6e 67 20 69 74 20 6f | 75 74 20 6f 66 20 61 6e |ing it o|ut of an|
|00005560| 20 61 72 63 68 69 76 65 | 2e 0d 0a 58 20 2a 20 0d | archive|...X * .|
|00005570| 0a 58 20 2a 20 4c 61 6e | 67 75 61 67 65 3a 20 43 |.X * Lan|guage: C|
|00005580| 6f 6d 70 75 74 65 72 20 | 49 6e 6e 6f 76 61 74 69 |omputer |Innovati|
|00005590| 6f 6e 73 20 4f 70 74 69 | 6d 69 7a 69 6e 67 20 43 |ons Opti|mizing C|
|000055a0| 38 36 0d 0a 58 20 2a 2f | 0d 0a 58 23 69 6e 63 6c |86..X */|..X#incl|
|000055b0| 75 64 65 20 3c 73 74 64 | 69 6f 2e 68 3e 0d 0a 58 |ude <std|io.h>..X|
|000055c0| 23 69 6e 63 6c 75 64 65 | 20 22 61 72 63 2e 68 22 |#include| "arc.h"|
|000055d0| 0d 0a 58 23 69 66 09 4d | 54 53 0d 0a 58 23 69 6e |..X#if.M|TS..X#in|
|000055e0| 63 6c 75 64 65 20 3c 63 | 74 79 70 65 2e 68 3e 0d |clude <c|type.h>.|
|000055f0| 0a 58 23 65 6e 64 69 66 | 0d 0a 58 0d 0a 58 76 6f |.X#endif|..X..Xvo|
|00005600| 69 64 09 73 65 74 63 6f | 64 65 28 29 2c 20 69 6e |id.setco|de(), in|
|00005610| 69 74 5f 75 73 71 28 29 | 2c 20 69 6e 69 74 5f 75 |it_usq()|, init_u|
|00005620| 63 72 28 29 2c 20 64 65 | 63 6f 6d 70 28 29 2c 20 |cr(), de|comp(), |
|00005630| 73 71 64 65 63 6f 6d 70 | 28 29 3b 0d 0a 58 76 6f |sqdecomp|();..Xvo|
|00005640| 69 64 09 61 62 6f 72 74 | 28 29 2c 20 70 75 74 63 |id.abort|(), putc|
|00005650| 5f 74 73 74 28 29 3b 0d | 0a 58 69 6e 74 09 67 65 |_tst();.|.Xint.ge|
|00005660| 74 63 5f 75 73 71 28 29 | 2c 20 67 65 74 63 5f 75 |tc_usq()|, getc_u|
|00005670| 63 72 28 29 2c 20 61 64 | 64 63 72 63 28 29 3b 0d |cr(), ad|dcrc();.|
|00005680| 0a 58 0d 0a 58 2f 2a 20 | 73 74 75 66 66 20 66 6f |.X..X/* |stuff fo|
|00005690| 72 20 72 65 70 65 61 74 | 20 75 6e 70 61 63 6b 69 |r repeat| unpacki|
|000056a0| 6e 67 20 2a 2f 0d 0a 58 | 0d 0a 58 23 64 65 66 69 |ng */..X|..X#defi|
|000056b0| 6e 65 20 44 4c 45 20 30 | 78 39 30 09 09 2f 2a 20 |ne DLE 0|x90../* |
|000056c0| 72 65 70 65 61 74 20 62 | 79 74 65 20 66 6c 61 67 |repeat b|yte flag|
|000056d0| 20 2a 2f 0d 0a 58 0d 0a | 58 73 74 61 74 69 63 20 | */..X..|Xstatic |
|000056e0| 69 6e 74 20 20 20 20 20 | 20 73 74 61 74 65 3b 09 |int | state;.|
|000056f0| 09 2f 2a 20 72 65 70 65 | 61 74 20 75 6e 70 61 63 |./* repe|at unpac|
|00005700| 6b 69 6e 67 20 73 74 61 | 74 65 20 2a 2f 0d 0a 58 |king sta|te */..X|
|00005710| 0d 0a 58 2f 2a 20 72 65 | 70 65 61 74 20 75 6e 70 |..X/* re|peat unp|
|00005720| 61 63 6b 69 6e 67 20 73 | 74 61 74 65 73 20 2a 2f |acking s|tates */|
|00005730| 0d 0a 58 0d 0a 58 23 64 | 65 66 69 6e 65 20 4e 4f |..X..X#d|efine NO|
|00005740| 48 49 53 54 20 30 09 09 | 2f 2a 20 6e 6f 20 72 65 |HIST 0..|/* no re|
|00005750| 6c 65 76 61 6e 74 20 68 | 69 73 74 6f 72 79 20 2a |levant h|istory *|
|00005760| 2f 0d 0a 58 23 64 65 66 | 69 6e 65 20 49 4e 52 45 |/..X#def|ine INRE|
|00005770| 50 20 31 09 09 09 2f 2a | 20 73 65 6e 64 69 6e 67 |P 1.../*| sending|
|00005780| 20 61 20 72 65 70 65 61 | 74 65 64 20 76 61 6c 75 | a repea|ted valu|
|00005790| 65 20 2a 2f 0d 0a 58 0d | 0a 58 73 74 61 74 69 63 |e */..X.|.Xstatic|
|000057a0| 20 73 68 6f 72 74 20 20 | 20 20 63 72 63 76 61 6c | short | crcval|
|000057b0| 3b 09 09 2f 2a 20 43 52 | 43 20 63 68 65 63 6b 20 |;../* CR|C check |
|000057c0| 76 61 6c 75 65 20 2a 2f | 0d 0a 58 73 74 61 74 69 |value */|..Xstati|
|000057d0| 63 20 6c 6f 6e 67 20 20 | 20 20 20 73 69 7a 65 3b |c long | size;|
|000057e0| 09 09 2f 2a 20 62 79 74 | 65 73 20 74 6f 20 72 65 |../* byt|es to re|
|000057f0| 61 64 20 2a 2f 0d 0a 58 | 23 69 66 09 21 44 4f 53 |ad */..X|#if.!DOS|
|00005800| 0d 0a 58 73 74 61 74 69 | 63 20 69 6e 74 09 67 6f |..Xstati|c int.go|
|00005810| 74 63 72 3b 09 09 2f 2a | 20 67 6f 74 20 61 20 63 |tcr;../*| got a c|
|00005820| 61 72 72 69 61 67 65 20 | 72 65 74 75 72 6e 3f 20 |arriage |return? |
|00005830| 2a 2f 0d 0a 58 23 65 6e | 64 69 66 0d 0a 58 0d 0a |*/..X#en|dif..X..|
|00005840| 58 69 6e 74 0d 0a 58 75 | 6e 70 61 63 6b 28 66 2c |Xint..Xu|npack(f,|
|00005850| 20 74 2c 20 68 64 72 29 | 09 09 2f 2a 20 75 6e 70 | t, hdr)|../* unp|
|00005860| 61 63 6b 20 61 6e 20 61 | 72 63 68 69 76 65 20 65 |ack an a|rchive e|
|00005870| 6e 74 72 79 20 2a 2f 0d | 0a 58 09 46 49 4c 45 20 |ntry */.|.X.FILE |
|00005880| 20 20 20 20 20 20 20 20 | 20 20 2a 66 2c 20 2a 74 | | *f, *t|
|00005890| 3b 09 2f 2a 20 73 6f 75 | 72 63 65 2c 20 64 65 73 |;./* sou|rce, des|
|000058a0| 74 69 6e 61 74 69 6f 6e | 20 2a 2f 0d 0a 58 09 73 |tination| */..X.s|
|000058b0| 74 72 75 63 74 20 68 65 | 61 64 73 20 20 20 2a 68 |truct he|ads *h|
|000058c0| 64 72 3b 09 2f 2a 20 70 | 6f 69 6e 74 65 72 20 74 |dr;./* p|ointer t|
|000058d0| 6f 20 66 69 6c 65 20 68 | 65 61 64 65 72 20 64 61 |o file h|eader da|
|000058e0| 74 61 20 2a 2f 0d 0a 58 | 7b 0d 0a 58 09 69 6e 74 |ta */..X|{..X.int|
|000058f0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 63 3b 09 | | c;.|
|00005900| 2f 2a 20 6f 6e 65 20 63 | 68 61 72 20 6f 66 20 73 |/* one c|har of s|
|00005910| 74 72 65 61 6d 20 2a 2f | 0d 0a 58 09 76 6f 69 64 |tream */|..X.void|
|00005920| 20 20 20 20 20 20 20 20 | 20 20 20 20 70 75 74 63 | | putc|
|00005930| 5f 75 6e 70 28 29 3b 0d | 0a 58 09 76 6f 69 64 20 |_unp();.|.X.void |
|00005940| 20 20 20 20 20 20 20 20 | 20 20 20 70 75 74 63 5f | | putc_|
|00005950| 6e 63 72 28 29 3b 0d 0a | 58 09 69 6e 74 20 20 20 |ncr();..|X.int |
|00005960| 20 20 20 20 20 20 20 20 | 20 20 67 65 74 63 5f 75 | | getc_u|
|00005970| 6e 70 28 29 3b 0d 0a 58 | 0d 0a 58 09 2f 2a 20 73 |np();..X|..X./* s|
|00005980| 65 74 75 70 73 20 63 6f | 6d 6d 6f 6e 20 74 6f 20 |etups co|mmon to |
|00005990| 61 6c 6c 20 6d 65 74 68 | 6f 64 73 20 2a 2f 0d 0a |all meth|ods */..|
|000059a0| 58 23 69 66 09 21 44 4f | 53 0d 0a 58 09 67 6f 74 |X#if.!DO|S..X.got|
|000059b0| 63 72 20 3d 20 30 3b 0d | 0a 58 23 65 6e 64 69 66 |cr = 0;.|.X#endif|
|000059c0| 0d 0a 58 09 63 72 63 76 | 61 6c 20 3d 20 30 3b 09 |..X.crcv|al = 0;.|
|000059d0| 09 2f 2a 20 72 65 73 65 | 74 20 43 52 43 20 63 68 |./* rese|t CRC ch|
|000059e0| 65 63 6b 20 76 61 6c 75 | 65 20 2a 2f 0d 0a 58 09 |eck valu|e */..X.|
|000059f0| 73 69 7a 65 20 3d 20 68 | 64 72 2d 3e 73 69 7a 65 |size = h|dr->size|
|00005a00| 3b 09 2f 2a 20 73 65 74 | 20 69 6e 70 75 74 20 62 |;./* set| input b|
|00005a10| 79 74 65 20 63 6f 75 6e | 74 65 72 20 2a 2f 0d 0a |yte coun|ter */..|
|00005a20| 58 09 73 74 61 74 65 20 | 3d 20 4e 4f 48 49 53 54 |X.state |= NOHIST|
|00005a30| 3b 09 09 2f 2a 20 69 6e | 69 74 69 61 6c 20 72 65 |;../* in|itial re|
|00005a40| 70 65 61 74 20 75 6e 70 | 61 63 6b 69 6e 67 20 73 |peat unp|acking s|
|00005a50| 74 61 74 65 20 2a 2f 0d | 0a 58 09 73 65 74 63 6f |tate */.|.X.setco|
|00005a60| 64 65 28 29 3b 09 09 2f | 2a 20 73 65 74 20 75 70 |de();../|* set up|
|00005a70| 20 66 6f 72 20 64 65 63 | 6f 64 69 6e 67 20 2a 2f | for dec|oding */|
|00005a80| 0d 0a 58 0d 0a 58 09 2f | 2a 20 75 73 65 20 77 68 |..X..X./|* use wh|
|00005a90| 61 74 65 76 65 72 20 6d | 65 74 68 6f 64 20 69 73 |atever m|ethod is|
|00005aa0| 20 61 70 70 72 6f 70 72 | 69 61 74 65 20 2a 2f 0d | appropr|iate */.|
|00005ab0| 0a 58 0d 0a 58 09 73 77 | 69 74 63 68 20 28 68 64 |.X..X.sw|itch (hd|
|00005ac0| 72 76 65 72 29 20 7b 09 | 2f 2a 20 63 68 6f 6f 73 |rver) {.|/* choos|
|00005ad0| 65 20 70 72 6f 70 65 72 | 20 75 6e 70 61 63 6b 20 |e proper| unpack |
|00005ae0| 6d 65 74 68 6f 64 20 2a | 2f 0d 0a 58 09 63 61 73 |method *|/..X.cas|
|00005af0| 65 20 31 3a 09 09 2f 2a | 20 73 74 61 6e 64 61 72 |e 1:../*| standar|
|00005b00| 64 20 70 61 63 6b 69 6e | 67 20 2a 2f 0d 0a 58 09 |d packin|g */..X.|
|00005b10| 63 61 73 65 20 32 3a 0d | 0a 58 09 09 77 68 69 6c |case 2:.|.X..whil|
|00005b20| 65 20 28 28 63 20 3d 20 | 67 65 74 63 5f 75 6e 70 |e ((c = |getc_unp|
|00005b30| 28 66 29 29 20 21 3d 20 | 45 4f 46 29 0d 0a 58 09 |(f)) != |EOF)..X.|
|00005b40| 09 09 70 75 74 63 5f 75 | 6e 70 28 28 63 68 61 72 |..putc_u|np((char|
|00005b50| 29 20 63 2c 20 74 29 3b | 0d 0a 58 09 09 62 72 65 |) c, t);|..X..bre|
|00005b60| 61 6b 3b 0d 0a 58 0d 0a | 58 09 63 61 73 65 20 33 |ak;..X..|X.case 3|
|00005b70| 3a 09 09 2f 2a 20 6e 6f | 6e 2d 72 65 70 65 61 74 |:../* no|n-repeat|
|00005b80| 20 70 61 63 6b 69 6e 67 | 20 2a 2f 0d 0a 58 09 09 | packing| */..X..|
|00005b90| 77 68 69 6c 65 20 28 28 | 63 20 3d 20 67 65 74 63 |while ((|c = getc|
|00005ba0| 5f 75 6e 70 28 66 29 29 | 20 21 3d 20 45 4f 46 29 |_unp(f))| != EOF)|
|00005bb0| 0d 0a 58 09 09 09 70 75 | 74 63 5f 6e 63 72 28 28 |..X...pu|tc_ncr((|
|00005bc0| 75 6e 73 69 67 6e 65 64 | 20 63 68 61 72 29 20 63 |unsigned| char) c|
|00005bd0| 2c 20 74 29 3b 0d 0a 58 | 09 09 62 72 65 61 6b 3b |, t);..X|..break;|
|00005be0| 0d 0a 58 0d 0a 58 09 63 | 61 73 65 20 34 3a 09 09 |..X..X.c|ase 4:..|
|00005bf0| 2f 2a 20 48 75 66 66 6d | 61 6e 20 73 71 75 65 65 |/* Huffm|an squee|
|00005c00| 7a 69 6e 67 20 2a 2f 0d | 0a 58 09 09 69 6e 69 74 |zing */.|.X..init|
|00005c10| 5f 75 73 71 28 66 29 3b | 0d 0a 58 09 09 77 68 69 |_usq(f);|..X..whi|
|00005c20| 6c 65 20 28 28 63 20 3d | 20 67 65 74 63 5f 75 73 |le ((c =| getc_us|
|00005c30| 71 28 66 29 29 20 21 3d | 20 45 4f 46 29 0d 0a 58 |q(f)) !=| EOF)..X|
|00005c40| 09 09 09 70 75 74 63 5f | 6e 63 72 28 28 75 6e 73 |...putc_|ncr((uns|
|00005c50| 69 67 6e 65 64 20 63 68 | 61 72 29 20 63 2c 20 74 |igned ch|ar) c, t|
|00005c60| 29 3b 0d 0a 58 09 09 62 | 72 65 61 6b 3b 0d 0a 58 |);..X..b|reak;..X|
|00005c70| 0d 0a 58 09 63 61 73 65 | 20 35 3a 09 09 2f 2a 20 |..X.case| 5:../* |
|00005c80| 4c 65 6d 70 65 6c 2d 5a | 65 76 20 63 6f 6d 70 72 |Lempel-Z|ev compr|
|00005c90| 65 73 73 69 6f 6e 20 2a | 2f 0d 0a 58 09 09 69 6e |ession *|/..X..in|
|00005ca0| 69 74 5f 75 63 72 28 30 | 29 3b 0d 0a 58 09 09 77 |it_ucr(0|);..X..w|
|00005cb0| 68 69 6c 65 20 28 28 63 | 20 3d 20 67 65 74 63 5f |hile ((c| = getc_|
|00005cc0| 75 63 72 28 66 29 29 20 | 21 3d 20 45 4f 46 29 0d |ucr(f)) |!= EOF).|
|00005cd0| 0a 58 09 09 09 70 75 74 | 63 5f 75 6e 70 28 28 63 |.X...put|c_unp((c|
|00005ce0| 68 61 72 29 20 63 2c 20 | 74 29 3b 0d 0a 58 09 09 |har) c, |t);..X..|
|00005cf0| 62 72 65 61 6b 3b 0d 0a | 58 0d 0a 58 09 63 61 73 |break;..|X..X.cas|
|00005d00| 65 20 36 3a 09 09 2f 2a | 20 4c 65 6d 70 65 6c 2d |e 6:../*| Lempel-|
|00005d10| 5a 65 76 20 70 6c 75 73 | 20 6e 6f 6e 2d 72 65 70 |Zev plus| non-rep|
|00005d20| 65 61 74 20 2a 2f 0d 0a | 58 09 09 69 6e 69 74 5f |eat */..|X..init_|
|00005d30| 75 63 72 28 30 29 3b 0d | 0a 58 09 09 77 68 69 6c |ucr(0);.|.X..whil|
|00005d40| 65 20 28 28 63 20 3d 20 | 67 65 74 63 5f 75 63 72 |e ((c = |getc_ucr|
|00005d50| 28 66 29 29 20 21 3d 20 | 45 4f 46 29 0d 0a 58 09 |(f)) != |EOF)..X.|
|00005d60| 09 09 70 75 74 63 5f 6e | 63 72 28 28 75 6e 73 69 |..putc_n|cr((unsi|
|00005d70| 67 6e 65 64 20 63 68 61 | 72 29 20 63 2c 20 74 29 |gned cha|r) c, t)|
|00005d80| 3b 0d 0a 58 09 09 62 72 | 65 61 6b 3b 0d 0a 58 0d |;..X..br|eak;..X.|
|00005d90| 0a 58 09 63 61 73 65 20 | 37 3a 09 09 2f 2a 20 4c |.X.case |7:../* L|
|00005da0| 2d 5a 20 70 6c 75 73 20 | 6e 63 72 20 77 69 74 68 |-Z plus |ncr with|
|00005db0| 20 6e 65 77 20 68 61 73 | 68 20 2a 2f 0d 0a 58 09 | new has|h */..X.|
|00005dc0| 09 69 6e 69 74 5f 75 63 | 72 28 31 29 3b 0d 0a 58 |.init_uc|r(1);..X|
|00005dd0| 09 09 77 68 69 6c 65 20 | 28 28 63 20 3d 20 67 65 |..while |((c = ge|
|00005de0| 74 63 5f 75 63 72 28 66 | 29 29 20 21 3d 20 45 4f |tc_ucr(f|)) != EO|
|00005df0| 46 29 0d 0a 58 09 09 09 | 70 75 74 63 5f 6e 63 72 |F)..X...|putc_ncr|
|00005e00| 28 28 75 6e 73 69 67 6e | 65 64 20 63 68 61 72 29 |((unsign|ed char)|
|00005e10| 20 63 2c 20 74 29 3b 0d | 0a 58 09 09 62 72 65 61 | c, t);.|.X..brea|
|00005e20| 6b 3b 0d 0a 58 0d 0a 58 | 09 63 61 73 65 20 38 3a |k;..X..X|.case 8:|
|00005e30| 09 09 2f 2a 20 64 79 6e | 61 6d 69 63 20 4c 65 6d |../* dyn|amic Lem|
|00005e40| 70 65 6c 2d 5a 65 76 20 | 2a 2f 0d 0a 58 09 09 64 |pel-Zev |*/..X..d|
|00005e50| 65 63 6f 6d 70 28 66 2c | 20 74 29 3b 0d 0a 58 09 |ecomp(f,| t);..X.|
|00005e60| 09 62 72 65 61 6b 3b 0d | 0a 58 0d 0a 58 09 63 61 |.break;.|.X..X.ca|
|00005e70| 73 65 20 39 3a 09 09 2f | 2a 20 53 71 75 61 73 68 |se 9:../|* Squash|
|00005e80| 69 6e 67 20 2a 2f 0d 0a | 58 09 09 73 71 64 65 63 |ing */..|X..sqdec|
|00005e90| 6f 6d 70 28 66 2c 20 74 | 29 3b 0d 0a 58 09 09 62 |omp(f, t|);..X..b|
|00005ea0| 72 65 61 6b 3b 0d 0a 58 | 0d 0a 58 09 64 65 66 61 |reak;..X|..X.defa|
|00005eb0| 75 6c 74 3a 09 09 2f 2a | 20 75 6e 6b 6e 6f 77 6e |ult:../*| unknown|
|00005ec0| 20 6d 65 74 68 6f 64 20 | 2a 2f 0d 0a 58 09 09 69 | method |*/..X..i|
|00005ed0| 66 20 28 77 61 72 6e 29 | 20 7b 0d 0a 58 09 09 09 |f (warn)| {..X...|
|00005ee0| 70 72 69 6e 74 66 28 22 | 49 20 64 6f 6e 27 74 20 |printf("|I don't |
|00005ef0| 6b 6e 6f 77 20 68 6f 77 | 20 74 6f 20 75 6e 70 61 |know how| to unpa|
|00005f00| 63 6b 20 66 69 6c 65 20 | 25 73 5c 6e 22 2c 20 68 |ck file |%s\n", h|
|00005f10| 64 72 2d 3e 6e 61 6d 65 | 29 3b 0d 0a 58 09 09 09 |dr->name|);..X...|
|00005f20| 70 72 69 6e 74 66 28 22 | 49 20 74 68 69 6e 6b 20 |printf("|I think |
|00005f30| 79 6f 75 20 6e 65 65 64 | 20 61 20 6e 65 77 65 72 |you need| a newer|
|00005f40| 20 76 65 72 73 69 6f 6e | 20 6f 66 20 41 52 43 5c | version| of ARC\|
|00005f50| 6e 22 29 3b 0d 0a 58 09 | 09 09 6e 65 72 72 73 2b |n");..X.|..nerrs+|
|00005f60| 2b 3b 0d 0a 58 09 09 7d | 0d 0a 58 09 09 66 73 65 |+;..X..}|..X..fse|
|00005f70| 65 6b 28 66 2c 20 68 64 | 72 2d 3e 73 69 7a 65 2c |ek(f, hd|r->size,|
|00005f80| 20 31 29 3b 09 2f 2a 20 | 73 6b 69 70 20 6f 76 65 | 1);./* |skip ove|
|00005f90| 72 20 62 61 64 20 66 69 | 6c 65 20 2a 2f 0d 0a 58 |r bad fi|le */..X|
|00005fa0| 09 09 72 65 74 75 72 6e | 20 31 3b 09 2f 2a 20 6e |..return| 1;./* n|
|00005fb0| 6f 74 65 20 64 65 66 65 | 63 74 69 76 65 20 66 69 |ote defe|ctive fi|
|00005fc0| 6c 65 20 2a 2f 0d 0a 58 | 09 7d 0d 0a 58 0d 0a 58 |le */..X|.}..X..X|
|00005fd0| 09 2f 2a 20 63 6c 65 61 | 6e 75 70 73 20 63 6f 6d |./* clea|nups com|
|00005fe0| 6d 6f 6e 20 74 6f 20 61 | 6c 6c 20 6d 65 74 68 6f |mon to a|ll metho|
|00005ff0| 64 73 20 2a 2f 0d 0a 58 | 0d 0a 58 09 69 66 20 28 |ds */..X|..X.if (|
|00006000| 63 72 63 76 61 6c 20 21 | 3d 20 68 64 72 2d 3e 63 |crcval !|= hdr->c|
|00006010| 72 63 29 20 7b 0d 0a 58 | 09 09 69 66 20 28 77 61 |rc) {..X|..if (wa|
|00006020| 72 6e 20 7c 7c 20 6b 6c | 75 64 67 65 29 20 7b 0d |rn || kl|udge) {.|
|00006030| 0a 58 09 09 09 70 72 69 | 6e 74 66 28 22 57 41 52 |.X...pri|ntf("WAR|
|00006040| 4e 49 4e 47 3a 20 46 69 | 6c 65 20 25 73 20 66 61 |NING: Fi|le %s fa|
|00006050| 69 6c 73 20 43 52 43 20 | 63 68 65 63 6b 5c 6e 22 |ils CRC |check\n"|
|00006060| 2c 20 68 64 72 2d 3e 6e | 61 6d 65 29 3b 0d 0a 58 |, hdr->n|ame);..X|
|00006070| 09 09 09 6e 65 72 72 73 | 2b 2b 3b 0d 0a 58 09 09 |...nerrs|++;..X..|
|00006080| 7d 0d 0a 58 09 09 72 65 | 74 75 72 6e 20 31 3b 09 |}..X..re|turn 1;.|
|00006090| 2f 2a 20 6e 6f 74 65 20 | 64 65 66 65 63 74 69 76 |/* note |defectiv|
|000060a0| 65 20 66 69 6c 65 20 2a | 2f 0d 0a 58 09 7d 0d 0a |e file *|/..X.}..|
|000060b0| 58 09 72 65 74 75 72 6e | 20 30 3b 09 09 2f 2a 20 |X.return| 0;../* |
|000060c0| 66 69 6c 65 20 69 73 20 | 6f 6b 61 79 20 2a 2f 0d |file is |okay */.|
|000060d0| 0a 58 7d 0d 0a 58 0d 0a | 58 2f 2a 0d 0a 58 20 2a |.X}..X..|X/*..X *|
|000060e0| 20 54 68 69 73 20 72 6f | 75 74 69 6e 65 20 69 73 | This ro|utine is|
|000060f0| 20 75 73 65 64 20 74 6f | 20 70 75 74 20 62 79 74 | used to| put byt|
|00006100| 65 73 20 69 6e 20 74 68 | 65 20 6f 75 74 70 75 74 |es in th|e output|
|00006110| 20 66 69 6c 65 2e 20 20 | 49 74 20 61 6c 73 6f 20 | file. |It also |
|00006120| 70 65 72 66 6f 72 6d 73 | 0d 0a 58 20 2a 20 76 61 |performs|..X * va|
|00006130| 72 69 6f 75 73 20 68 6f | 75 73 65 6b 65 65 70 69 |rious ho|usekeepi|
|00006140| 6e 67 20 66 75 6e 63 74 | 69 6f 6e 73 2c 20 73 75 |ng funct|ions, su|
|00006150| 63 68 20 61 73 20 6d 61 | 69 6e 74 61 69 6e 69 6e |ch as ma|intainin|
|00006160| 67 20 74 68 65 20 43 52 | 43 20 63 68 65 63 6b 20 |g the CR|C check |
|00006170| 76 61 6c 75 65 2e 0d 0a | 58 20 2a 2f 0d 0a 58 0d |value...|X */..X.|
|00006180| 0a 58 76 6f 69 64 0d 0a | 58 70 75 74 63 5f 75 6e |.Xvoid..|Xputc_un|
|00006190| 70 28 63 2c 20 74 29 09 | 09 09 2f 2a 20 6f 75 74 |p(c, t).|../* out|
|000061a0| 70 75 74 20 61 6e 20 75 | 6e 70 61 63 6b 65 64 20 |put an u|npacked |
|000061b0| 62 79 74 65 20 2a 2f 0d | 0a 58 09 63 68 61 72 20 |byte */.|.X.char |
|000061c0| 20 20 20 20 20 20 20 20 | 20 20 20 63 3b 09 2f 2a | | c;./*|
|000061d0| 20 62 79 74 65 20 74 6f | 20 6f 75 74 70 75 74 20 | byte to| output |
|000061e0| 2a 2f 0d 0a 58 09 46 49 | 4c 45 20 20 20 20 20 20 |*/..X.FI|LE |
|000061f0| 20 20 20 20 20 2a 74 3b | 09 2f 2a 20 66 69 6c 65 | *t;|./* file|
|00006200| 20 74 6f 20 6f 75 74 70 | 75 74 20 74 6f 20 2a 2f | to outp|ut to */|
|00006210| 0d 0a 58 7b 0d 0a 58 09 | 63 72 63 76 61 6c 20 3d |..X{..X.|crcval =|
|00006220| 20 61 64 64 63 72 63 28 | 63 72 63 76 61 6c 2c 20 | addcrc(|crcval, |
|00006230| 63 29 3b 09 2f 2a 20 75 | 70 64 61 74 65 20 74 68 |c);./* u|pdate th|
|00006240| 65 20 43 52 43 20 63 68 | 65 63 6b 20 76 61 6c 75 |e CRC ch|eck valu|
|00006250| 65 20 2a 2f 0d 0a 58 23 | 69 66 09 4d 54 53 0d 0a |e */..X#|if.MTS..|
|00006260| 58 09 69 66 20 28 21 69 | 6d 61 67 65 29 0d 0a 58 |X.if (!i|mage)..X|
|00006270| 09 09 61 74 6f 65 28 26 | 63 2c 20 31 29 3b 0d 0a |..atoe(&|c, 1);..|
|00006280| 58 23 65 6e 64 69 66 0d | 0a 58 23 69 66 09 44 4f |X#endif.|.X#if.DO|
|00006290| 53 0d 0a 58 09 70 75 74 | 63 5f 74 73 74 28 63 2c |S..X.put|c_tst(c,|
|000062a0| 20 74 29 3b 0d 0a 58 23 | 65 6c 73 65 0d 0a 58 09 | t);..X#|else..X.|
|000062b0| 69 66 20 28 69 6d 61 67 | 65 29 0d 0a 58 09 09 70 |if (imag|e)..X..p|
|000062c0| 75 74 63 5f 74 73 74 28 | 63 2c 20 74 29 3b 0d 0a |utc_tst(|c, t);..|
|000062d0| 58 09 65 6c 73 65 20 7b | 0d 0a 58 09 09 69 66 20 |X.else {|..X..if |
|000062e0| 28 67 6f 74 63 72 29 20 | 7b 0d 0a 58 09 09 09 67 |(gotcr) |{..X...g|
|000062f0| 6f 74 63 72 20 3d 20 30 | 3b 0d 0a 58 09 09 09 69 |otcr = 0|;..X...i|
|00006300| 66 20 28 63 20 21 3d 20 | 27 5c 6e 27 29 0d 0a 58 |f (c != |'\n')..X|
|00006310| 09 09 09 09 70 75 74 63 | 5f 74 73 74 28 27 5c 72 |....putc|_tst('\r|
|00006320| 27 2c 20 74 29 3b 0d 0a | 58 09 09 7d 0d 0a 58 09 |', t);..|X..}..X.|
|00006330| 09 69 66 20 28 63 20 3d | 3d 20 27 5c 72 27 29 0d |.if (c =|= '\r').|
|00006340| 0a 58 09 09 09 67 6f 74 | 63 72 20 3d 20 31 3b 0d |.X...got|cr = 1;.|
|00006350| 0a 58 09 09 65 6c 73 65 | 0d 0a 58 09 09 09 70 75 |.X..else|..X...pu|
|00006360| 74 63 5f 74 73 74 28 63 | 2c 20 74 29 3b 0d 0a 58 |tc_tst(c|, t);..X|
|00006370| 09 7d 0d 0a 58 23 65 6e | 64 69 66 0d 0a 58 7d 0d |.}..X#en|dif..X}.|
|00006380| 0a 58 0d 0a 58 2f 2a 0d | 0a 58 20 2a 20 54 68 69 |.X..X/*.|.X * Thi|
|00006390| 73 20 72 6f 75 74 69 6e | 65 20 69 73 20 75 73 65 |s routin|e is use|
|000063a0| 64 20 74 6f 20 64 65 63 | 6f 64 65 20 6e 6f 6e 2d |d to dec|ode non-|
|000063b0| 72 65 70 65 61 74 20 63 | 6f 6d 70 72 65 73 73 69 |repeat c|ompressi|
|000063c0| 6f 6e 2e 20 20 42 79 74 | 65 73 20 61 72 65 20 70 |on. Byt|es are p|
|000063d0| 61 73 73 65 64 0d 0a 58 | 20 2a 20 6f 6e 65 20 61 |assed..X| * one a|
|000063e0| 74 20 61 20 74 69 6d 65 | 20 69 6e 20 63 6f 64 65 |t a time| in code|
|000063f0| 64 20 66 6f 72 6d 61 74 | 2c 20 61 6e 64 20 61 72 |d format|, and ar|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.